.navigation{background:#fff;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:1000;padding:1rem 0}.navigation .nav-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}.navigation .logo{font-size:1.5rem;font-weight:700;color:#2563eb;text-decoration:none;transition:color .3s ease}.navigation .logo:hover{color:#134cca}.navigation .nav-links{display:flex;list-style:none;gap:2rem;margin:0;padding:0;flex-wrap:wrap}.navigation .nav-links li a{color:#333;text-decoration:none;font-weight:500;padding:.5rem 0;position:relative;transition:color .3s ease}.navigation .nav-links li a:hover,.navigation .nav-links li a.active{color:#2563eb}.navigation .nav-links li a.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:#2563eb}@media(max-width:768px){.navigation .nav-content{flex-direction:column;gap:1rem}.navigation .nav-links{gap:1rem;justify-content:center}}.footer{background:#1f2937;color:#fff;padding:3rem 20px 1rem;margin-top:4rem}.footer .footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:2rem}@media(max-width:768px){.footer .footer-content{grid-template-columns:1fr;gap:1.5rem;text-align:center}}.footer .footer-section h3{font-size:1.5rem;margin-bottom:1rem;color:#fff}.footer .footer-section h4{font-size:1.2rem;margin-bottom:1rem;color:#fff}.footer .footer-section p{color:#9ca3af;line-height:1.6}.footer .footer-section ul{list-style:none;padding:0;margin:0}.footer .footer-section ul li{margin-bottom:.5rem}.footer .footer-section ul li a{color:#9ca3af;text-decoration:none;transition:color .3s ease}.footer .footer-section ul li a:hover{color:#fff}.footer .footer-bottom{border-top:1px solid #374151;padding-top:1.5rem;text-align:center}.footer .footer-bottom p{color:#9ca3af;margin:0}.home-page .hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:80px 20px;text-align:center}.home-page .hero h1{font-size:3.5rem;margin-bottom:1rem;font-weight:700}.home-page .hero .subtitle{font-size:1.5rem;margin-bottom:1.5rem;opacity:.95}.home-page .hero .description{font-size:1.1rem;max-width:800px;margin:0 auto;opacity:.9;line-height:1.8}.home-page .branches{padding:80px 20px;background:#f9fafb}.home-page .branches h2{text-align:center;font-size:2.5rem;margin-bottom:3rem;color:#333}.home-page .branches .branch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1200px;margin:0 auto}@media(max-width:768px){.home-page .branches .branch-grid{grid-template-columns:1fr;gap:1.5rem}}.home-page .branches .branch-card{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a;text-align:center;transition:transform .3s ease,box-shadow .3s ease}@media(max-width:768px){.home-page .branches .branch-card{padding:2rem}}.home-page .branches .branch-card:hover{transform:translateY(-5px);box-shadow:0 8px 16px #00000026}@media(max-width:768px){.home-page .branches .branch-card:hover{transform:none}}.home-page .branches .branch-card .branch-icon{font-size:4rem;margin-bottom:1rem}.home-page .branches .branch-card h3{font-size:1.8rem;margin-bottom:1rem;color:#333}.home-page .branches .branch-card p{color:#666;margin-bottom:2rem;line-height:1.6}.home-page .branches .branch-card .btn{display:inline-block;padding:12px 30px;background:#2563eb;color:#fff;text-decoration:none;border-radius:6px;font-weight:500;transition:background .3s ease}.home-page .branches .branch-card .btn:hover{background:#134cca}.responsive-image{overflow:hidden;background:#f9fafb}.responsive-image img{display:block;width:100%;height:100%;object-fit:cover}.responsive-image--gallery{aspect-ratio:16/10;border-radius:8px}.responsive-image--gallery img{width:100%;height:100%}.responsive-image--profile{width:100px;height:100px;border-radius:50%;margin:0 auto 1.5rem;flex-shrink:0}@media(min-width:1025px){.responsive-image--profile{width:140px;height:140px}}.about-page .about-hero{background:linear-gradient(135deg,#2563eb,#1043b3);color:#fff;padding:100px 0 80px;text-align:center}.about-page .about-hero h1{font-size:3rem;margin-bottom:1rem;font-weight:700}.about-page .about-hero .subtitle{font-size:1.4rem;opacity:.9}@media(max-width:768px){.about-page .about-hero{padding:60px 0 50px}.about-page .about-hero h1{font-size:2rem}.about-page .about-hero .subtitle{font-size:1.1rem}}.about-page .about-story{padding:80px 0;background:#f9fafb}.about-page .about-story .story-content{max-width:800px;margin:0 auto;text-align:center}.about-page .about-story .story-content h2{font-size:2.2rem;color:#2563eb;margin-bottom:2rem}.about-page .about-story .story-content p{font-size:1.1rem;color:#666;line-height:1.8;margin-bottom:1.5rem}@media(max-width:768px){.about-page .about-story{padding:50px 0}.about-page .about-story .story-content h2{font-size:1.8rem}}.about-page .about-mission{padding:80px 0}.about-page .about-mission .mission-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}@media(max-width:768px){.about-page .about-mission .mission-grid{grid-template-columns:1fr}}@media(min-width:769px)and (max-width:1024px){.about-page .about-mission .mission-grid{grid-template-columns:repeat(2,1fr)}}.about-page .about-mission .mission-card{background:#fff;padding:40px 30px;border-radius:12px;box-shadow:0 4px 20px #00000014;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.about-page .about-mission .mission-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px #0000001f}.about-page .about-mission .mission-card .mission-icon{font-size:3rem;margin-bottom:1.5rem}.about-page .about-mission .mission-card h3{font-size:1.4rem;color:#2563eb;margin-bottom:1rem}.about-page .about-mission .mission-card p{color:#666;line-height:1.7}.about-page .about-team{padding:80px 0;background:#f9fafb}.about-page .about-team h2{text-align:center;font-size:2.2rem;color:#2563eb;margin-bottom:3rem}.about-page .about-team .team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;justify-items:center}.about-page .about-team .team-card{background:#fff;padding:40px 30px;border-radius:12px;box-shadow:0 4px 20px #00000014;text-align:center;max-width:320px;width:100%}.about-page .about-team .team-card h3{font-size:1.3rem;color:#333;margin-bottom:.5rem}.about-page .about-team .team-card .team-role{color:#2563eb;font-weight:600;margin-bottom:1rem}.about-page .about-team .team-card .team-bio{color:#666;font-size:.95rem;line-height:1.6}@media(max-width:768px){.about-page .about-team{padding:50px 0}.about-page .about-team h2{font-size:1.8rem}}.about-page .about-stats{padding:80px 0;background:linear-gradient(135deg,#2563eb,#134cca)}.about-page .about-stats .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}@media(max-width:768px){.about-page .about-stats .stats-grid{grid-template-columns:repeat(2,1fr)}}.about-page .about-stats .stat-item{text-align:center;color:#fff}.about-page .about-stats .stat-item .stat-number{display:block;font-size:3rem;font-weight:700;margin-bottom:.5rem}.about-page .about-stats .stat-item .stat-label{font-size:1rem;opacity:.9}@media(max-width:768px){.about-page .about-stats{padding:50px 0}.about-page .about-stats .stat-item .stat-number{font-size:2.2rem}}.contact-form-container{max-width:600px;margin:0 auto}.contact-form-container .contact-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}@media(max-width:768px){.contact-form-container .contact-form{padding:1.5rem}}.contact-form-container .form-group{margin-bottom:1.5rem}.contact-form-container .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.contact-form-container .form-group input,.contact-form-container .form-group textarea{width:100%;padding:.75rem;border:1px solid #e5e7eb;border-radius:4px;font-size:1rem;font-family:inherit;transition:border-color .3s ease}.contact-form-container .form-group input:focus,.contact-form-container .form-group textarea:focus{outline:none;border-color:#2563eb}.contact-form-container .form-group input:disabled,.contact-form-container .form-group textarea:disabled{background:#f9fafb;cursor:not-allowed}.contact-form-container .form-group textarea{resize:vertical}.contact-form-container .form-message{padding:1rem;border-radius:4px;margin-bottom:1rem}.contact-form-container .form-message.success{background:#d1fae5;color:#065f46;border:1px solid #10b981}.contact-form-container .form-message.error{background:#fee2e2;color:#991b1b;border:1px solid #dc2626}.contact-form-container .btn-submit{width:100%;padding:.875rem;background:#2563eb;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .3s ease}.contact-form-container .btn-submit:hover:not(:disabled){background:#134cca}.contact-form-container .btn-submit:disabled{background:#9ca3af;cursor:not-allowed}.image-carousel{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:1200px;margin:0 auto}.image-carousel__row{display:flex;align-items:center;gap:1rem;width:100%;min-width:0}@media(max-width:768px){.image-carousel__row{gap:.5rem}}.image-carousel__btn{flex-shrink:0;width:48px;height:48px;border-radius:50%;border:2px solid #2563eb;background:#fff;color:#2563eb;font-size:1.5rem;line-height:1;cursor:pointer;transition:background .2s,color .2s;display:flex;align-items:center;justify-content:center;padding:0}.image-carousel__btn:hover{background:#2563eb;color:#fff}.image-carousel__btn:focus-visible{outline:2px solid #2563eb;outline-offset:2px}@media(max-width:768px){.image-carousel__btn{width:40px;height:40px;font-size:1.25rem}}.image-carousel__viewport{flex:1;min-width:0;overflow:hidden}.image-carousel__track{display:flex;width:calc(var(--carousel-track-width, 233.33) * 1%);transition:transform .35s ease-out;transform:translate(calc(-1 * var(--carousel-index, 0) * var(--carousel-slide-width, 33.333) * 1%))}.image-carousel__slide{flex:0 0 calc(var(--carousel-slide-width, 33.333) * 1%);padding:0 .5rem;min-width:0;box-sizing:border-box}@media(max-width:768px){.image-carousel__slide{padding:0 .25rem}}.image-carousel__dots{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;width:100%;order:1}.image-carousel__dot{width:10px;height:10px;border-radius:50%;border:none;background:#e5e7eb;cursor:pointer;padding:0;transition:background .2s,transform .2s}.image-carousel__dot:hover{background:#c8ccd5}.image-carousel__dot--active{background:#2563eb;transform:scale(1.2)}.image-carousel__dot:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.jp-energy-page .hero{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;padding:60px 20px;text-align:center}.jp-energy-page .hero h1{font-size:3rem;margin-bottom:1rem}.jp-energy-page .hero .subtitle{font-size:1.3rem;opacity:.95}.jp-energy-page .about{padding:60px 20px;background:#fff}.jp-energy-page .about h2{font-size:2.5rem;margin-bottom:2rem;color:#333;text-align:center}.jp-energy-page .about p{font-size:1.1rem;line-height:1.8;color:#666;max-width:800px;margin:0 auto;text-align:center}.jp-energy-page .gallery{padding:60px 20px;background:#f9fafb}.jp-energy-page .gallery h2{font-size:2.5rem;margin-bottom:1rem;color:#333;text-align:center}.jp-energy-page .gallery .gallery-intro{font-size:1.1rem;color:#666;text-align:center;max-width:600px;margin:0 auto 3rem;line-height:1.6}.jp-energy-page .services{padding:60px 20px;background:#f9fafb}.jp-energy-page .services h2{font-size:2.5rem;margin-bottom:3rem;color:#333;text-align:center}.jp-energy-page .services .services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1200px;margin:0 auto}@media(max-width:768px){.jp-energy-page .services .services-grid{grid-template-columns:1fr;gap:1.5rem}}.jp-energy-page .services .service-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.jp-energy-page .services .service-card h3{font-size:1.5rem;margin-bottom:1rem;color:#333}.jp-energy-page .services .service-card p{color:#666;line-height:1.6}.jp-energy-page .contact{padding:60px 20px;background:#fff}.jp-energy-page .contact h2{font-size:2.5rem;margin-bottom:1rem;color:#333;text-align:center}.jp-energy-page .contact>p{text-align:center;color:#666;margin-bottom:3rem;font-size:1.1rem}.jp-solutions-page .hero{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;padding:60px 20px;text-align:center}.jp-solutions-page .hero h1{font-size:3rem;margin-bottom:1rem}.jp-solutions-page .hero .subtitle{font-size:1.3rem;opacity:.95}.jp-solutions-page .about{padding:60px 20px;background:#fff}.jp-solutions-page .about h2{font-size:2.5rem;margin-bottom:2rem;color:#333;text-align:center}.jp-solutions-page .about p{font-size:1.1rem;line-height:1.8;color:#666;max-width:800px;margin:0 auto;text-align:center}.jp-solutions-page .services{padding:60px 20px;background:#f9fafb}.jp-solutions-page .services h2{font-size:2.5rem;margin-bottom:3rem;color:#333;text-align:center}.jp-solutions-page .services .services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1200px;margin:0 auto}@media(max-width:768px){.jp-solutions-page .services .services-grid{grid-template-columns:1fr;gap:1.5rem}}.jp-solutions-page .services .service-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.jp-solutions-page .services .service-card h3{font-size:1.5rem;margin-bottom:1rem;color:#333}.jp-solutions-page .services .service-card p{color:#666;line-height:1.6}.jp-solutions-page .project-allecc{padding:60px 20px;background:#fff;text-align:center}.jp-solutions-page .project-allecc h2{font-size:2.5rem;margin-bottom:1rem;color:#333}.jp-solutions-page .project-allecc p{font-size:1.1rem;color:#666;margin-bottom:2rem}.jp-solutions-page .project-allecc .allecc-link{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}@media(max-width:480px){.jp-solutions-page .project-allecc .allecc-link{flex-direction:column;align-items:center}}.jp-solutions-page .project-allecc .allecc-link .btn{padding:12px 30px;border-radius:6px;text-decoration:none;font-weight:500;transition:all .3s ease;display:inline-block}.jp-solutions-page .project-allecc .allecc-link .btn.btn-secondary{background:#059669;color:#fff}.jp-solutions-page .project-allecc .allecc-link .btn.btn-secondary:hover{background:#036546}.jp-solutions-page .project-allecc .allecc-link .btn.btn-outline{background:transparent;color:#2563eb;border:2px solid #2563eb}.jp-solutions-page .project-allecc .allecc-link .btn.btn-outline:hover{background:#2563eb;color:#fff}.jp-solutions-page .contact{padding:60px 20px;background:#f9fafb}.jp-solutions-page .contact h2{font-size:2.5rem;margin-bottom:1rem;color:#333;text-align:center}.jp-solutions-page .contact>p{text-align:center;color:#666;margin-bottom:3rem;font-size:1.1rem}.project-allecc-page .hero{background:linear-gradient(135deg,#fa709a,#fee140);color:#fff;padding:60px 20px;text-align:center}.project-allecc-page .hero h1{font-size:3rem;margin-bottom:1rem}.project-allecc-page .hero .subtitle{font-size:1.3rem;opacity:.95}.project-allecc-page .about{padding:60px 20px;background:#fff;text-align:center}.project-allecc-page .about h2{font-size:2.5rem;margin-bottom:2rem;color:#333}.project-allecc-page .about p{font-size:1.1rem;line-height:1.8;color:#666;max-width:800px;margin:0 auto 2rem}.project-allecc-page .about .external-link{margin-top:2rem}.project-allecc-page .about .external-link .btn{padding:12px 30px;background:#2563eb;color:#fff;text-decoration:none;border-radius:6px;font-weight:500;transition:background .3s ease;display:inline-block}.project-allecc-page .about .external-link .btn:hover{background:#134cca}.project-allecc-page .focus{padding:60px 20px;background:#f9fafb}.project-allecc-page .focus h2{font-size:2.5rem;margin-bottom:3rem;color:#333;text-align:center}.project-allecc-page .focus .focus-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1200px;margin:0 auto}@media(max-width:768px){.project-allecc-page .focus .focus-grid{grid-template-columns:1fr;gap:1.5rem}}.project-allecc-page .focus .focus-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center}.project-allecc-page .focus .focus-card h3{font-size:1.5rem;margin-bottom:1rem;color:#333}.project-allecc-page .focus .focus-card p{color:#666;line-height:1.6}.project-allecc-page .contact{padding:60px 20px;background:#fff}.project-allecc-page .contact h2{font-size:2.5rem;margin-bottom:1rem;color:#333;text-align:center}.project-allecc-page .contact>p{text-align:center;color:#666;margin-bottom:3rem;font-size:1.1rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{max-width:1200px;margin:0 auto;padding:0 20px}.text-center{text-align:center}.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}.mb-1{margin-bottom:1rem}.mb-2{margin-bottom:2rem}.mb-3{margin-bottom:3rem}
