*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #2d6a4f;--secondary-color: #52b788;--accent-color: #95d5b2;--dark-color: #1b4332;--light-color: #d8f3dc;--gray-100: #f8f9fa;--gray-200: #e9ecef;--gray-300: #dee2e6;--gray-600: #6c757d;--gray-800: #343a40;--white: #ffffff;--text-color: #2b2d42;--border-radius: 8px;--box-shadow: 0 2px 10px rgba(0, 0, 0, .1);--transition: all .3s ease}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;color:var(--text-color);background-color:var(--gray-100)}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1}.container{max-width:1200px;margin:0 auto;padding:0 20px}.navbar{background:var(--white);box-shadow:0 2px 5px #0000001a;position:sticky;top:0;z-index:1000}.navbar .container{display:flex;justify-content:space-between;align-items:center;padding:1rem 20px}.nav-brand a{text-decoration:none;color:var(--text-color)}.nav-brand h2{font-size:1.5rem;color:var(--primary-color);margin-bottom:.25rem}.nav-brand .location{font-size:.875rem;color:var(--gray-600)}.nav-menu{display:flex;list-style:none;gap:2rem}.nav-menu a{text-decoration:none;color:var(--text-color);font-weight:500;transition:var(--transition);padding:.5rem 0}.nav-menu a:hover,.nav-menu a.active{color:var(--primary-color)}.hamburger{display:none;flex-direction:column;cursor:pointer;gap:4px}.hamburger span{width:25px;height:3px;background:var(--text-color);transition:var(--transition)}.hero{position:relative;height:600px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--dark-color) 100%);display:flex;align-items:center;justify-content:center;text-align:center;color:var(--white);overflow:hidden}.hero-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><rect fill="%23ffffff" opacity="0.05" width="100" height="100"/></svg>');background-size:50px 50px}.hero-slider{height:700px}.slider-container{position:absolute;top:0;left:0;width:100%;height:100%}.slide{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;opacity:0;transition:opacity 1s ease-in-out;pointer-events:none}.slide.active{opacity:1;pointer-events:auto}.slide-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,#2d6a4f4d,#1b4332b3)}.slider-btn{position:absolute;top:50%;transform:translateY(-50%);background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);color:var(--white);font-size:3rem;width:60px;height:60px;border-radius:50%;cursor:pointer;transition:var(--transition);z-index:10;display:flex;align-items:center;justify-content:center;line-height:1;padding:0}.slider-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-50%) scale(1.1)}.slider-btn.prev{left:2rem}.slider-btn.next{right:2rem}.slider-dots{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;gap:1rem;z-index:10}.dot{width:12px;height:12px;border-radius:50%;background:#fff6;border:2px solid rgba(255,255,255,.6);cursor:pointer;transition:var(--transition);padding:0}.dot:hover{background:#fff9;transform:scale(1.2)}.dot.active{background:var(--white);border-color:var(--white);transform:scale(1.3)}.hero-content{position:relative;z-index:1;max-width:800px;padding:2rem}.hero-title{font-size:3.5rem;font-weight:700;margin-bottom:1rem;line-height:1.2}.hero-subtitle{font-size:1.25rem;margin-bottom:2rem;opacity:.95}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{padding:.75rem 1.5rem;border:none;border-radius:var(--border-radius);font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition);text-decoration:none;display:inline-block;text-align:center}.btn-primary{background:var(--primary-color);color:var(--white)}.btn-primary:hover{background:var(--dark-color);transform:translateY(-2px)}.btn-secondary{background:var(--white);color:var(--primary-color);border:2px solid var(--primary-color)}.btn-secondary:hover{background:var(--primary-color);color:var(--white)}.btn-block{width:100%}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.features{padding:4rem 0;background:var(--white)}.section-title{text-align:center;font-size:2.5rem;margin-bottom:3rem;color:var(--primary-color)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.feature-card{text-align:center;padding:2rem;border-radius:var(--border-radius);background:var(--gray-100);transition:var(--transition)}.feature-card:hover{transform:translateY(-5px);box-shadow:var(--box-shadow)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{font-size:1.25rem;margin-bottom:.5rem;color:var(--primary-color)}.stats{padding:3rem 0;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:var(--white)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem}.stat-item{text-align:center}.stat-number{font-size:3rem;font-weight:700;margin-bottom:.5rem}.stat-label{font-size:1rem;opacity:.9}.quick-access{padding:4rem 0;background:var(--white)}.access-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.access-card{padding:2rem;border-radius:var(--border-radius);background:var(--white);border:2px solid var(--gray-300);transition:var(--transition);text-decoration:none;color:var(--text-color);display:block}.access-card:hover{border-color:var(--primary-color);transform:translateY(-5px);box-shadow:var(--box-shadow)}.access-icon{font-size:2.5rem;margin-bottom:1rem}.access-card h3{color:var(--primary-color);margin-bottom:.5rem}.access-card .arrow{display:block;margin-top:1rem;font-size:1.5rem;color:var(--primary-color)}.cta{padding:4rem 0;background:var(--light-color);text-align:center}.cta h2{font-size:2.5rem;margin-bottom:1rem;color:var(--primary-color)}.cta-buttons{display:flex;gap:1rem;justify-content:center;margin-top:2rem;flex-wrap:wrap}.page-header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--dark-color) 100%);color:var(--white);padding:4rem 0 3rem;text-align:center}.page-header h1{font-size:3rem;margin-bottom:1rem}.content-section{padding:4rem 0;background:var(--white)}.content-grid{display:grid;grid-template-columns:1fr 350px;gap:3rem}.content-main h2{color:var(--primary-color);margin-top:2rem;margin-bottom:1rem}.content-main h3{color:var(--dark-color);margin-top:1.5rem;margin-bottom:.75rem}.lead{font-size:1.25rem;color:var(--gray-600);margin-bottom:2rem}.info-box{background:var(--light-color);padding:1.5rem;border-radius:var(--border-radius);margin:1.5rem 0;border-left:4px solid var(--primary-color)}.info-box h4{color:var(--primary-color);margin-bottom:.75rem}.checkmark-list{list-style:none}.checkmark-list li:before{content:"✓ ";color:var(--primary-color);font-weight:700;margin-right:.5rem}.timeline{margin:2rem 0}.timeline-item{display:flex;gap:1.5rem;margin-bottom:2rem}.timeline-marker{width:40px;height:40px;background:var(--primary-color);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.timeline-content h4{color:var(--primary-color);margin-bottom:.5rem}.timeline-duration{display:block;color:var(--gray-600);font-size:.875rem;margin-top:.5rem}.timeline-total{text-align:center;font-size:1.125rem;padding:1.5rem;background:var(--light-color);border-radius:var(--border-radius);margin-top:2rem}.sidebar-card{background:var(--gray-100);padding:1.5rem;border-radius:var(--border-radius);margin-bottom:1.5rem}.sidebar-card h3{color:var(--primary-color);margin-bottom:1rem;font-size:1.25rem}.detail-item{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--gray-300)}.detail-item:last-child{border-bottom:none}.detail-label{font-weight:600;color:var(--gray-600)}.status-approved{color:var(--primary-color);font-weight:600}.status-pending{color:#f39c12;font-weight:600}.system-list{list-style:none}.system-list li{padding:.75rem 0;border-bottom:1px solid var(--gray-300);display:flex;align-items:center;gap:.5rem}.cta-card{background:var(--primary-color);color:var(--white)}.cta-card h3{color:var(--white)}.contractor-section{margin-bottom:4rem}.contractor-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem}.contractor-icon{font-size:4rem}.contractor-subtitle{color:var(--gray-600);font-size:1.125rem}.contractor-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem}.scope-list,.requirements-list{margin:1rem 0}.highlight-box{background:var(--accent-color);padding:1.5rem;border-radius:var(--border-radius);margin:1.5rem 0}.highlight-box h4{color:var(--dark-color);margin-bottom:.5rem}.contractor-actions{display:flex;flex-direction:column;gap:1.5rem}.action-card{background:var(--gray-100);padding:1.5rem;border-radius:var(--border-radius);text-align:center}.action-card h4{color:var(--primary-color);margin-bottom:.5rem}.section-divider{height:2px;background:var(--gray-300);margin:3rem 0}.submission-guidelines{margin:4rem 0}.guidelines-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}.guideline-card{background:var(--white);padding:2rem;border-radius:var(--border-radius);border:2px solid var(--gray-300);text-align:center}.guideline-card h3{color:var(--primary-color);margin-bottom:1rem}.contact-box{background:var(--light-color);padding:2rem;border-radius:var(--border-radius);margin-top:3rem;text-align:center}.contact-box h3{color:var(--primary-color);margin-bottom:1rem}.contact-info{margin-top:1.5rem}.contact-info p{margin:.5rem 0}.why-join{margin:4rem 0}.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-top:2rem}.benefit-item{text-align:center}.benefit-icon{font-size:2.5rem;margin-bottom:1rem}.benefit-item h3{font-size:1.125rem;margin-bottom:.5rem;color:var(--primary-color)}.doc-section{margin-bottom:4rem}.section-description{color:var(--gray-600);font-size:1.125rem;margin-bottom:2rem}.doc-category{margin-bottom:3rem}.doc-category h3{color:var(--primary-color);margin-bottom:1.5rem;font-size:1.5rem}.doc-item{display:flex;justify-content:space-between;align-items:center;background:var(--white);padding:1.5rem;border-radius:var(--border-radius);border:1px solid var(--gray-300);margin-bottom:1rem}.doc-info h4{color:var(--primary-color);margin-bottom:.5rem}.password-gate{display:flex;justify-content:center;padding:3rem 0}.password-box{background:var(--white);padding:3rem;border-radius:var(--border-radius);box-shadow:var(--box-shadow);max-width:500px;width:100%;text-align:center}.password-box h3{color:var(--primary-color);margin-bottom:1rem}.password-box form{margin-top:2rem}.password-input{width:100%;padding:.75rem;border:2px solid var(--gray-300);border-radius:var(--border-radius);font-size:1rem;margin-bottom:1rem}.password-hint{margin-top:1rem;color:var(--gray-600)}.error-message{background:#dc3545;color:var(--white);padding:.75rem;border-radius:var(--border-radius);margin-top:1rem}.success-message{background:var(--secondary-color);color:var(--white);padding:1rem;border-radius:var(--border-radius);margin-bottom:2rem;text-align:center}.doc-subcategory{margin-bottom:2rem}.doc-subcategory h4{color:var(--dark-color);margin-bottom:1rem}.doc-list{display:flex;flex-direction:column;gap:.75rem}.doc-item-small{display:flex;align-items:center;justify-content:space-between;background:var(--gray-100);padding:.75rem 1rem;border-radius:var(--border-radius);gap:1rem}.file-icon{font-size:1.25rem;flex-shrink:0}.file-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.file-name{font-weight:500;color:var(--text-color)}.file-desc{font-size:.875rem;color:var(--gray-600)}.file-note{font-size:.875rem;color:var(--gray-600);font-style:italic;margin-bottom:1rem}.doc-organization{margin-top:4rem}.org-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:2rem}.org-card{background:var(--gray-100);padding:1.5rem;border-radius:var(--border-radius);text-align:center;min-height:150px;display:flex;flex-direction:column;justify-content:space-between}.org-card h4{color:var(--primary-color);margin-bottom:.5rem;font-size:1rem;word-wrap:break-word}.org-card p{font-size:.875rem;color:var(--gray-600);margin-bottom:1rem;line-height:1.4;min-height:40px}.file-count{display:inline-block;background:var(--primary-color);color:var(--white);padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600;white-space:nowrap}.upload-section{background:var(--white);padding:2rem;border-radius:var(--border-radius);box-shadow:var(--box-shadow);margin-bottom:3rem}.admin-auth{max-width:500px;margin:0 auto;text-align:center;padding:2rem}.auth-message{color:var(--gray-600);margin-bottom:1.5rem;font-size:1rem}.auth-form{text-align:left}.auth-form .form-group{margin-bottom:1rem}.auth-form button{width:100%}.upload-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--dark-color)}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:2px solid var(--gray-300);border-radius:var(--border-radius);font-size:1rem;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color)}.filter-section{margin-bottom:3rem}.filter-buttons{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.filter-btn{padding:.5rem 1rem;border:2px solid var(--gray-300);background:var(--white);border-radius:20px;cursor:pointer;font-weight:500;transition:var(--transition)}.filter-btn:hover,.filter-btn.active{background:var(--primary-color);color:var(--white);border-color:var(--primary-color)}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-top:2rem}.photo-card{background:var(--white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--box-shadow);transition:var(--transition)}.photo-card:hover{transform:translateY(-5px);box-shadow:0 4px 20px #00000026}.photo-image{width:100%;height:250px;overflow:hidden;background:var(--gray-200)}.photo-image img{width:100%;height:100%;object-fit:cover}.photo-info{padding:1rem;position:relative}.photo-caption{font-weight:500;margin-bottom:.5rem}.photo-meta{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:var(--gray-600)}.photo-category{background:var(--accent-color);padding:.25rem .5rem;border-radius:4px;text-transform:capitalize}.btn-delete{position:absolute;top:1rem;right:1rem;background:#dc3545e6;border:none;padding:.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:var(--transition)}.btn-delete:hover{background:#dc3545}.no-photos{text-align:center;padding:3rem;color:var(--gray-600)}.create-post-section{margin-bottom:2rem}.post-form-section{margin-bottom:4rem}.post-form-card{background:var(--white);padding:2rem;border-radius:var(--border-radius);box-shadow:var(--box-shadow)}.post-form-card h2{color:var(--primary-color);margin-bottom:1.5rem}.form-actions{display:flex;gap:1rem}.posts-timeline{display:flex;flex-direction:column;gap:2rem;margin-top:2rem}.post-card{background:var(--white);padding:2rem;border-radius:var(--border-radius);box-shadow:var(--box-shadow)}.post-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--gray-200)}.post-meta{display:flex;flex-direction:column;gap:.25rem}.post-date{font-weight:600;color:var(--primary-color)}.post-author{font-size:.875rem;color:var(--gray-600)}.post-actions{display:flex;gap:.5rem}.btn-icon{background:transparent;border:none;cursor:pointer;font-size:1.25rem;padding:.25rem;transition:var(--transition)}.btn-icon:hover{transform:scale(1.2)}.post-content h3{color:var(--dark-color);margin-bottom:1rem}.post-text p{margin-bottom:1rem;line-height:1.8}.no-posts{text-align:center;padding:3rem;color:var(--gray-600)}.journey-info{margin-top:4rem;padding:3rem;background:var(--light-color);border-radius:var(--border-radius)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}.info-card{background:var(--white);padding:1.5rem;border-radius:var(--border-radius)}.info-card h4{color:var(--primary-color);margin-bottom:.75rem}.info-card a{color:var(--primary-color);text-decoration:underline}.footer{background:var(--dark-color);color:var(--white);padding:3rem 0 1rem}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}.footer-section h3,.footer-section h4{margin-bottom:1rem;color:var(--accent-color)}.footer-section ul{list-style:none}.footer-section ul li{margin-bottom:.5rem}.footer-section a{color:var(--white);text-decoration:none;transition:var(--transition)}.footer-section a:hover{color:var(--accent-color)}.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1)}.loading{text-align:center;padding:3rem;font-size:1.125rem;color:var(--gray-600)}@media (max-width: 968px){.content-grid,.contractor-content{grid-template-columns:1fr}}@media (max-width: 768px){.nav-menu{position:fixed;left:-100%;top:70px;flex-direction:column;background-color:var(--white);width:100%;text-align:center;transition:var(--transition);box-shadow:0 10px 27px #0000000d;padding:2rem 0}.nav-menu.open{left:0}.hamburger{display:flex}.hero-slider{height:500px}.slider-btn{width:40px;height:40px;font-size:2rem}.slider-btn.prev{left:1rem}.slider-btn.next{right:1rem}.slider-dots{bottom:1rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.page-header h1{font-size:2rem}.photos-grid{grid-template-columns:1fr}}
