/* ================================
   GLOBAL STYLES (All Pages)
=================================== */
body{font-family:Arial,sans-serif;margin:0;background-color:#f7f7f7;color:#222;line-height:1.6}
a{text-decoration:none}
img{max-width:100%;height:auto;display:block}
h1,h2,h3{margin-top:0}

/* ================================
   HEADER & NAVIGATION
=================================== */
header{background-color:#111;color:#fff;padding:1rem 2rem;position:sticky;top:0;z-index:1000;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.header-container{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap}
.logo h1{font-size:2rem;color:#e60000;margin:0}
.logo .tagline{font-size:.9rem;color:#ccc;margin-top:.2rem}
nav ul{list-style:none;display:flex;gap:2rem;margin:0;padding:0}
nav ul li{margin:0}
nav a{color:white;font-weight:bold;font-size:1.1rem;position:relative;transition:color .2s ease}
nav a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background-color:#e60000;transition:width .3s ease}
nav a:hover::after,nav a.active::after{width:100%}
nav a:hover,nav a.active{color:#e60000}
.nav-toggle{display:none;background:none;border:none;color:white;font-size:2rem;cursor:pointer}
@media(max-width:768px){nav ul{flex-direction:column;display:none;width:100%;text-align:center;background-color:#111;position:absolute;top:70px;left:0;padding:1rem 0}nav ul.show{display:flex}nav ul li{margin:1rem 0}.nav-toggle{display:block}}
a:focus,button:focus,input:focus,textarea:focus{outline:3px solid rgba(230,0,0,.15);outline-offset:2px}

/* ================================
   FOOTER
=================================== */
footer{background-color:#111;color:#ccc;text-align:center;padding:1rem 0;margin-top:3rem}
footer a{color:#e60000}
footer a:hover{text-decoration:underline}

/* ================================
   MAIN STYLING
=================================== */
main{padding:2rem;text-align:center}
main h2{color:#e60000}

/* ================================
   HERO / BANNER
=================================== */
.hero{background:url('Images/CompanyLogos/HeaderBanner.jpeg') no-repeat center center;background-size:cover;color:white;padding:6rem 1rem;text-align:center;max-height:500px;overflow:hidden}
.hero-content h2{font-size:2.5rem;font-weight:800;margin-bottom:1rem;text-shadow:-3px -3px 6px rgba(0,0,0,.95),3px -3px 6px rgba(0,0,0,.95),-3px 3px 6px rgba(0,0,0,.95),3px 3px 6px rgba(0,0,0,.95)}
.hero-content p{font-size:1.2rem;text-shadow:-3px -3px 6px black,3px -3px 6px black,-3px 3px 6px black,3px 3px 6px black}
.hero-btn{background-color:#e60000;color:#fff;padding:.8rem 1.8rem;border-radius:6px;font-weight:bold;transition:background .3s}
.hero-btn:hover{background-color:#ff1a1a}

/* ================================
   SERVICES SECTION
=================================== */
.services{padding:3rem 1rem;background-color:#fff}
.service-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:2rem;margin-top:2rem}
.service-card{background-color:#f5f5f5;padding:1.5rem;border-radius:8px;width:260px;box-shadow:0 0 8px rgba(0,0,0,.1);transition:transform .3s ease,box-shadow .3s ease}
.service-card:hover{transform:translateY(-6px);box-shadow:0 6px 12px rgba(0,0,0,.2)}
.service-photo{width:100%;height:140px;overflow:hidden;border-radius:6px;margin-bottom:1rem}
.service-photo img{width:100%;height:100%;object-fit:cover;border-radius:6px}
.service-photo.center img{display:block;margin:0 auto}

/* ================================
   PORTFOLIO GRID
=================================== */
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:2rem}
.project-card{background-color:#f9f9f9;border-radius:10px;box-shadow:0 4px 12px rgba(0,0,0,.1);overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}
.project-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px rgba(0,0,0,.15)}
.project-info{padding:1rem;text-align:left}
.project-info h3{margin-top:0;color:#e60000}

/* ================================
   FEATURED PROJECTS
=================================== */
.featured-projects{padding:3rem 1rem;background-color:#111;color:white}
.featured-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;margin:2rem 0}
.featured-photo{background-color:#222;border:2px dashed #555;width:250px;height:150px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-weight:bold}
.view-more-btn{background-color:#e60000;color:#fff;padding:.7rem 1.5rem;border-radius:6px;font-weight:bold;transition:background .3s}
.view-more-btn:hover{background-color:#ff1a1a}
.featured-slideshow{width:250px!important;min-width:250px!important;max-width:250px!important;height:150px!important;min-height:150px!important;max-height:150px!important;position:relative;overflow:hidden;border-radius:8px;background-color:#222;box-shadow:0 4px 10px rgba(0,0,0,.25)}
.featured-slideshow img{width:100%;height:100%;object-fit:cover;position:absolute;top:0;left:0;opacity:1;transition:opacity 1.5s ease-in-out}

/* ================================
   CALL TO ACTION
=================================== */
.call-to-action{background-color:#e60000;color:#fff;padding:3rem 1rem}
.cta-btn{background-color:#000;color:#fff;padding:.8rem 1.5rem;border-radius:6px;font-weight:bold;transition:background .3s}
.cta-btn:hover{background-color:#222}

/* ================================
   ABOUT PAGE
=================================== */
.about-container{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center}
.about-left,.about-center,.about-right{background-color:#fff;padding:2rem;border-radius:10px;box-shadow:0 5px 15px rgba(0,0,0,.1);flex:1 1 300px;max-width:400px;text-align:left}
.photo-placeholder{background-color:#ddd;border:2px dashed #aaa;height:200px;display:flex;align-items:center;justify-content:center;border-radius:8px}

/* ================================
   CONTACT FORM
=================================== */
.contact-form-section{max-width:700px;margin:2rem auto;background-color:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 5px 20px rgba(0,0,0,.1);text-align:left}
.contact-form{display:flex;flex-direction:column;gap:1.5rem}
.contact-form select,.contact-form input,.contact-form textarea{width:100%;padding:1rem;border:1px solid #ccc;border-radius:8px;font-size:1rem;transition:border .3s,box-shadow .3s}
.contact-form select:focus,.contact-form input:focus,.contact-form textarea:focus{border-color:#e60000;box-shadow:0 0 8px rgba(230,0,0,.3);outline:none}
.contact-form textarea{min-height:300px;resize:vertical}
.contact-form button{background-color:#e60000;color:#fff;padding:1rem;border-radius:8px;font-size:1.1rem;font-weight:bold;cursor:pointer;transition:background .3s,transform .2s}
.contact-form button:hover{background-color:#ff1a1a;transform:scale(1.02)}

/* ================================
   IMAGE CAROUSEL
=================================== */
.carousel{position:relative;width:100%;max-width:600px;margin:0 auto;overflow:hidden;border-radius:6px;display:block;padding:.5rem;background-color:#f0f0f0}
.carousel-images{display:block}
.carousel-slide{display:none;width:100%}
.carousel-slide.active{display:block}
.carousel-slide img{width:100%;height:auto;display:block;border-radius:6px}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background-color:rgba(0,0,0,.4);color:white;border:none;font-size:1.5rem;cursor:pointer;padding:.4rem .8rem;border-radius:50%;transition:background .3s;z-index:10}
.carousel-btn:hover{background-color:rgba(0,0,0,.7)}
.carousel-btn.prev{left:8px}
.carousel-btn.next{right:8px}
.carousel-caption{position:absolute;bottom:8px;left:8px;background-color:rgba(0,0,0,.6);color:#fff;padding:.3rem .8rem;border-radius:6px;font-size:.9rem;font-weight:bold;letter-spacing:.5px}

/* ================================
   CONTACT INFO
=================================== */
.contact-info-section{max-width:700px;margin:2rem auto;padding:2.5rem;background-color:#fff;border-radius:12px;box-shadow:0 5px 20px rgba(0,0,0,.1);text-align:left}
.contact-info-section h2{text-align:center;margin-bottom:2rem;color:#e60000}
.contact-info-box{font-size:1.1rem;line-height:1.7}
.contact-info-box h3{margin-top:1.5rem;color:#e60000}
.contact-phone{font-size:1.4rem;margin:.5rem 0}
.contact-address,.contact-email{margin:.5rem 0 1.5rem 0}
.contact-info-box hr{border:none;border-top:1px solid #ddd;margin:1.5rem 0}