
:root{--primary-light:#798a56;
  --bg:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --primary:#4c5b31;
  --accent:#ff7a00;
  --accent-2:#99c2b1;
  --card:#ffffff;
  --border:#e5e7eb;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica,Arial}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(1160px,92%);margin:0 auto}
.site-header{position:sticky;top:0;background:#5b6543;box-shadow:0 1px 0 var(--border);z-index:50box-shadow:0 1px 0 var(--border);z-index:50box-shadow:0 1px 0 var(--border);z-index:50}
.header-bar{display:flex;align-items:center;gap:2rem;min-height:160px}
.brand{display:flex;gap:.5rem;align-items:center;font-weight:700;color:var(--text)}
.brand img{height:140px;width:auto}
.nav{display:flex;gap:1rem;align-items:center}
.nav a{padding:.4rem .6rem;border-radius:.6rem}
.nav a.btn{color:#111}
.nav .btn-primary{background:var(--accent);border:2px solid transparent}
.nav .btn-primary:hover{background:#ffa24a}
.nav-toggle{display:none;background:none;border:none;font-size:1.5rem}
.hero{position:relative;min-height:72vh;display:grid;place-items:center;overflow:hidden;background:#000}
.hero .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.6)}
.hero .content{position:relative;color:#fff;text-align:center;padding:3rem 1rem}
.hero h1{font-size:clamp(2rem,5vw,3.2rem);margin:0 0 .5rem}
.hero p{font-size:clamp(1rem,2.2vw,1.25rem);opacity:.9}
.hero .cta{margin-top:1.25rem;display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1rem;border-radius:999px;border:2px solid var(--accent);font-weight:600;cursor:pointer;background:#ffffff}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--accent);color:#111}
.section{padding:4rem 0}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:1.25rem;padding:1.2rem}
.badge{display:inline-block;background:var(--primary-light);color:#053;padding:.25rem .6rem;border-radius:.5rem;font-weight:600}
.kicker{letter-spacing:.08em;font-weight:700;color:var(--primary);text-transform:uppercase}
.feature{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem;align-items:center}
.feature:nth-child(even){grid-template-columns:.8fr 1.2fr}
.site-footer{background:#5b6543;color:#e8f3ee;margin-top:2rem;padding:2rem 0}color:#e8f3ee;margin-top:2rem;padding:2rem 0}
.site-footer a{color:#e8f3ee}
.site-footer .legal{margin-top:1rem;border-top:1px solid #2a3a31;padding-top:1rem;text-align:center}
.list-unstyled{list-style:none;padding-left:0;margin:0}
.form{display:grid;gap:1rem}
.input{padding:.8rem;border:1px solid var(--border);border-radius:.8rem;width:100%}
textarea.input{min-height:160px}
.alert{padding:.8rem 1rem;border-radius:.8rem;border:1px solid var(--border);background:#fff9f1}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.service-tile{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1rem;display:flex;flex-direction:column;gap:.6rem}
blockquote{border-left:4px solid var(--accent);padding-left:1rem;margin-left:0;color:#374151}
.placeholder{background:linear-gradient(135deg, #ffffff 0%, #eef4ef 100%);border:1px dashed #2b4d3a;display:grid;place-items:center;border-radius:1rem;aspect-ratio:16/9;color:#2b4d3a;font-weight:700}
@media (max-width: 900px){
  .grid-3,.grid-2,.feature{grid-template-columns:1fr}
  .nav{display:none;flex-direction:column;align-items:flex-start;background:#fff;position:absolute;top:66px;right:1rem;left:1rem;padding:1rem;border:1px solid var(--border);border-radius:1rem}
  .nav.open{display:flex}
  .nav-toggle{display:block}
}


/* YouTube background hero */
.hero { position: relative; height: 72vh; overflow: hidden; }
.hero .video-bg { position: absolute; inset: 0; width: 100%; height: 100%; overflow: hidden; }
.hero .video-bg iframe { width: 100%; height: 100%; pointer-events: none; }
.hero .content { position: relative; color: #fff; text-align: center; z-index: 1; padding: 3rem 1rem; }

.section-hero-intro{padding:2.5rem 0 1rem;background:#5b6543;color:#fff} .hero-title{color:#fff;margin:0 0 .4rem} .hero-sub{color:#fff;font-size:clamp(1.06rem,2.2vw,1.3rem)}

/* Contrast adjustments for dark background */
.nav a { color: #f3f4f6; }
.nav a:hover { color: #ffffff; }
.btn { background: #ffffff; color: #111; border-color: var(--accent); }
.btn.btn-primary { background: var(--accent); color: #111; border-color: var(--accent); }
.card { backdrop-filter: blur(4px); }

.brand img { height: 64px; width: auto; }

.hero-title { color: #ff7a00; font-size: clamp(2.2rem, 6vw, 3.6rem); }
.hero-sub { color: #ffffff; font-size: clamp(1.1rem, 2.5vw, 1.4rem); }

h1, h2, h3, h4, h5, h6 { color: #ff7a00; }

a[href*="Learn more"], .service-tile a { color: #ff7a00 !important; font-weight: 600; }
a[href*="Learn more"]:hover, .service-tile a:hover { text-decoration: underline; }

.badge { display: none !important; }

h1,h2,h3,h4{color:#4c5b31;}
.card a, .service-tile a { color: #4c5b31; }
.card a:hover, .service-tile a:hover { text-decoration: underline; }



.ba{position:relative;max-width:1100px;margin:1rem auto;border-radius:1rem;overflow:hidden;border:1px solid var(--border)}
.ba img{display:block;width:100%;height:auto}
.ba .after{position:absolute;inset:0;clip-path:inset(0 0 0 50%)} /* start half-half */
.ba .handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:var(--accent);box-shadow:0 0 0 2px rgba(0,0,0,.2)}
.ba .knob{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:#fff;border:2px solid var(--accent);border-radius:999px;width:26px;height:26px}

.gallery-grid {display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}
.gallery-grid img{width:100%;height:auto;border-radius:0.75rem;box-shadow:0 2px 6px rgba(0,0,0,.15);}

/* Gallery spacing */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.6rem}
.gallery-grid .tile{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 6px 12px rgba(0,0,0,.05)}
.gallery-grid .tile img{display:block;width:100%;height:auto;aspect-ratio:1/1;object-fit:cover}



.site-footer h4 { color: #ff7a00; }
.site-footer a { color: #ff7a00; }
.site-footer a:hover { text-decoration: underline; }

.caption{font-size:0.9rem;color:#555;margin-top:0.25rem;font-style:italic;text-align:center;}


/* Improved gallery spacing and alignment */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  align-items: start;
}
.gallery-grid img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 6px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}
.caption, .subcaption {
  text-align: center;
  margin-top: 0.4rem;
}
.subcaption {
  font-size: 0.9rem;
  color: #555;
  font-style: italic;
}

.gallery-grid .tile h4 {
  font-size: 1.25rem;
  font-weight: 600;
  color: #4c5b31;
  margin: 0.6rem 0.8rem 0.4rem;
}
.gallery-grid .tile p {
  font-size: 0.95rem;
  color: #374151;
  margin: 0 0.8rem 0.8rem;
}

.gallery-grid .tile img[src*="reclamation.jpg"] {
  object-position: bottom;
}

/* Gallery typography normalization */
.gallery-grid .tile{display:flex;flex-direction:column}
.gallery-grid .tile h4{
  margin:.6rem .8rem 0;
  color:#4c5b31;
  font-size:1.1rem;
  font-weight:700;
  line-height:1.25;
  text-align:left;
}
.gallery-grid .tile p{
  margin:.2rem .8rem .8rem;
  color:#374151;
  font-size:0.975rem;
  line-height:1.45;
  text-align:left;
 font-weight:400;}

/* Make reclamation image show bottom machinery more prominently */
.gallery-grid .tile img[src$="reclamation.jpg"]{
  object-position:center 85%;
}

.team-photo-small{max-width:250px;display:block;margin:0 auto;border-radius:6px;}

.about-team-photo {
  float: right;
  max-width: 40%;
  margin: 0 0 1rem 1.5rem;
  text-align: center;
}
.about-team-photo img {
  width: 100%;
  border-radius: 8px;
}
.about-team-photo .caption {
  font-size: 0.9rem;
  color: #555;
  margin-top: 0.25rem;
  font-style: italic;
}

.reviews-heading {
  margin-top: 1rem;
  color: #4c5b31;
  font-size: 1.5rem;
  font-weight: 700;
  text-align: left;
}


.site-footer {
  color: #fff;
}
.site-footer h4 {
  color: #ff7a00; /* orange headings */
}
.site-footer a, .site-footer p, .site-footer small, .site-footer li {
  color: #fff;
}
.site-footer a:hover {
  text-decoration: underline;
}

.site-footer a {
  color: #fff;
  transition: color 0.3s ease, text-decoration-color 0.3s ease;
}

.site-footer a:hover {
  color: #ffb366; /* lighter orange hover */
  text-decoration: underline;
  text-decoration-color: #ffb366;
}

.gallery-grid .tile.grease-cleanup p {
  margin-top: 0.2rem;
  margin-bottom: 0.4rem;
}

.reviews-embed {
  display: flex;
  justify-content: center;
}
.reviews-embed iframe {
  border-radius: 12px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
  max-width: 100%;
}

/* About page rebuilt layout */
.your-team-photo-card{
  background:#fff;
  border:1px solid rgba(0,0,0,0.08);
  border-radius:12px;
  padding:1rem;
  text-align:center;
  box-shadow:0 2px 10px rgba(0,0,0,0.06);
}
.your-team-photo-card h2{
  margin:0 0 .5rem;
  color:#4c5b31;
  font-size:1.25rem;
  font-weight:700;
}
.team-photo-card-img{
  width:100%;
  height:auto;
  max-width:460px;
  border-radius:8px;
  display:block;
  margin:0 auto;
}
.caption{
  font-size:0.9rem;
  color:#555;
  margin-top:0.4rem;
  font-style:italic;
  text-align:center;
}


.navbar ul ul {
  background-color: #4c5b31; /* army green background */
}
.navbar ul ul li a {
  color: #fff; /* white text */
}
.navbar ul ul li a:hover {
  background-color: #ff7a00; /* orange hover */
  color: #fff;
}

/* Dropdown menu styling */
.navbar ul ul {
  background-color: #4c5b31 !important; /* army green background */
  padding: 0;
  margin: 0;
}
.navbar ul ul li a {
  color: #fff !important; /* white text */
  padding: 10px 15px;
  display: block;
}
.navbar ul ul li a:hover {
  background-color: #ff7a00 !important; /* orange hover */
  color: #fff !important;
  transition: background-color 0.3s ease;
}

/* Dropdown shadow */
.navbar ul ul {
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}

/* Dropdown rounded corners */
.navbar ul ul {
  border-radius: 6px;
  overflow: hidden;
}

/* FORCE dropdown menu to use brand colors */
.navbar ul ul {
  background-color: #4c5b31 !important; /* army green */
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}

.navbar ul ul li a {
  background-color: #4c5b31 !important;
  color: #fff !important;
  display: block;
  padding: 10px 15px;
}

.navbar ul ul li a:hover {
  background-color: #ff7a00 !important; /* orange */
  color: #fff !important;
}

/* Force dropdown menu to use brand colors */
.navbar ul ul {
  background-color: #4c5b31 !important; /* army green */
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}

.navbar ul ul li a {
  background-color: #4c5b31 !important;
  color: #fff !important;
  display: block;
  padding: 10px 15px;
}

.navbar ul ul li a:hover {
  background-color: #ff7a00 !important; /* orange */
  color: #fff !important;
}

/* Dropdown menu alternate style */
.navbar ul ul {
  background-color: #fff !important; /* white background */
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}

.navbar ul ul li a {
  color: #4c5b31 !important; /* army green text */
  display: block;
  padding: 10px 15px;
}

.navbar ul ul li a:hover {
  background-color: #ff7a00 !important; /* orange hover */
  color: #fff !important;
}

/* --- Mobile nav dropdown fix (force brand colors when open) --- */
@media (max-width: 900px){
  .site-header .nav.open{
    background-color: #4c5b31 !important; /* army green */
    border: 1px solid transparent;
    border-radius: 12px;
  }
  .site-header .nav.open a{
    color: #ffffff !important;
    display: block;
    width: 100%;
    padding: 10px 12px;
    border-radius: 8px;
  }
  .site-header .nav.open a:hover{
    background-color: #ff7a00 !important; /* orange hover */
    color: #ffffff !important;
    text-decoration: none;
  }
  .site-header .nav-toggle{
    color: #ffffff;
  }
}
