:root{
  --green-600:#40b93c; /* primary */
  --green-500:#80cc28; /* accent */
  --green-100:#dfffba; /* tint */
  --white:#ffffff;
  --ink:#18221f;
  --muted:#5b6b63;
  --bg:#fcfffa;
  --ring: 0 0 0 3px color-mix(in oklab, var(--green-600) 30%, transparent);
  --error: #dc2626;
  --success: #16a34a;
}
/* CSS Reset (modern, minimal) */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";color:var(--ink);background:var(--bg);line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--green-600);outline-offset:2px;}

/* Layout */
.container{width:min(1200px, 92vw);margin-inline:auto}
header{position:sticky;top:0;z-index:1000;background:color-mix(in oklab, var(--white) 90%, var(--green-100) 10%);backdrop-filter:saturate(1.1) blur(6px);border-bottom:1px solid color-mix(in oklab, var(--green-600) 20%, transparent)}

/* Top bar */
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:12px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:0.2px}
/* .logo{width:36px;height:36px;display:grid;place-items:center;border-radius:10px;background:conic-gradient(from 180deg, var(--green-600), var(--green-500));color:white;font-weight:900} */
.menu{display:flex;align-items:center;gap:26px}
.menu a{font-weight:600;opacity:.9}
.menu a:hover{opacity:1}
.cta{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:14px;background:linear-gradient(135deg, var(--green-600), color-mix(in oklab, var(--green-500) 70%, var(--green-600) 30%));color:white;font-weight:700;box-shadow:0 10px 18px -8px color-mix(in oklab, var(--green-600) 40%, #000 60%);transform:translateZ(0)}
.cta:hover{filter:saturate(1.1);transform:translateY(-1px)}

.logo {
  width: 160px;
  height: auto;
  display: grid;
  place-items: center;
}

.logo-img {
  width: 100%;
  height: auto;
  object-fit: contain; /* ensures image scales correctly */
  display: block;
}


/* Mobile nav */
.burger{display:none;position:relative;width:44px;height:44px;border-radius:12px;border:1px solid color-mix(in oklab, var(--green-600) 22%, transparent);background:linear-gradient(180deg, #fff, var(--green-100));}
.burger span,.burger::before,.burger::after{content:"";position:absolute;left:11px;right:11px;height:2px;background:var(--green-600);transition:transform .35s ease, top .35s ease, opacity .25s ease}
.burger span{top:21px}
.burger::before{top:15px}
.burger::after{top:27px}
.burger.active span{opacity:0}
.burger.active::before{top:21px;transform:rotate(45deg)}
.burger.active::after{top:21px;transform:rotate(-45deg)}
.mobile-panel{position:fixed;inset:0 0 auto auto;width:min(340px, 90vw);height:100dvh;background:var(--white);box-shadow:-8px 0 30px -14px rgba(0,0,0,.18);transform:translateX(100%);transition:transform .35s ease;display:flex;flex-direction:column;padding:22px;gap:16px;z-index: 1001;}
.mobile-panel.open{transform:translateX(0)}
.mobile-panel a{padding:12px 10px;border-radius:10px;border:1px solid color-mix(in oklab, var(--green-600) 15%, transparent)}

/* Add close button to mobile menu */
.mobile-panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid color-mix(in oklab, var(--green-600) 15%, transparent);
}

.close-menu {
  background: none;
  border: none;
  font-size: 1.5rem;
  cursor: pointer;
  color: var(--muted);
}
.close-menu:hover {
  color: var(--ink);
}

/* Hero */
.hero{position:relative;overflow:hidden}
.hero .container{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;padding:54px 0 28px}
.eyebrow{display:inline-block;font-weight:800;letter-spacing:.4px;background:var(--green-100);color:var(--green-600);padding:6px 10px;border-radius:999px}
h1{font-size:clamp(2rem, 5vw + .2rem, 3.2rem);line-height:1.15;margin:.4rem 0}
.lead{font-size:clamp(1rem, 1.4vw + .4rem, 1.2rem);color:var(--muted);margin-bottom:18px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.outline{padding:10px 16px;border-radius:14px;border:2px solid var(--green-600);font-weight:700}
/* .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:22px}
.stat{background:var(--white);border:1px solid color-mix(in oklab, var(--green-600) 15%, transparent);border-radius:16px;padding:14px;text-align:center}
.stat strong{display:block;font-size:clamp(1.2rem, 2.5vw, 1.8rem)} */

.highlights {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 22px;
}

.highlight {
  background: var(--white);
  border: 1px solid color-mix(in oklab, var(--green-600) 15%, transparent);
  border-radius: 16px;
  padding: 18px;
  text-align: center;
  box-shadow: 0 10px 20px -10px rgba(0,0,0,.08);
}

.highlight strong {
  display: block;
  font-size: 1.2rem;
  color: var(--green-600);
  margin-bottom: 6px;
}

/* Responsive adjustments */
@media (max-width: 980px) {
  .highlights {
    grid-template-columns: repeat(2, 1fr); /* 2 per row on tablets */
  }
}

@media (max-width: 640px) {
  .highlights {
    grid-template-columns: 1fr; /* 1 per row on mobile */
  }
}

/* Hero art */
.plate{aspect-ratio:1/1;border-radius:50%;background:radial-gradient(circle at 30% 30%, var(--green-100), #fff 60%), conic-gradient(from 0deg, color-mix(in oklab, var(--green-600) 10%, #fff 90%), #fff);
  border:10px solid #f1f6ea;box-shadow:0 30px 60px -24px rgba(64,185,60,.35);position:relative;isolation:isolate}
.leaf{position:absolute;width:44%;aspect-ratio:1/1;border-radius:44% 56% 60% 40%/40% 60% 44% 56%;background:radial-gradient(circle at 30% 30%, #9be15d, var(--green-500));filter:drop-shadow(4px 10px 10px rgba(0,0,0,.08))}
.leaf:nth-child(1){left:8%;top:10%;animation:float 8s ease-in-out infinite}
.leaf:nth-child(2){right:6%;top:24%;transform:rotate(40deg);animation:float 10s ease-in-out infinite -2s}
.leaf:nth-child(3){left:24%;bottom:8%;transform:rotate(-25deg);animation:float 9s ease-in-out infinite -1s}
@keyframes float{0%,100%{transform:translateY(0) rotate(var(--r,0))}50%{transform:translateY(-10px) rotate(calc(var(--r,0) + 2deg))}}

/* Sections */
section{padding:64px 0}
.section-title{font-size:clamp(1.6rem, 2.6vw, 2.2rem);margin-bottom:8px}
.section-desc{color:var(--muted);margin-bottom:26px}

/* Services */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{grid-column:span 4;background:var(--white);border:1px solid color-mix(in oklab, var(--green-600) 15%, transparent);border-radius:18px;padding:18px;box-shadow:0 20px 30px -24px rgba(0,0,0,.1);transform:translateZ(0)}
.card h3{margin:.3rem 0}
.card p{color:var(--muted)}
.card:hover{translate:0 -3px}
.chip{display:inline-block;padding:4px 10px;border-radius:999px;background:var(--green-100);color:var(--green-600);font-weight:700;font-size:.85rem}

.about {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: center;
}

.about-illus {
  border-radius: 0;
  overflow: hidden;
  min-height: 280px;
  display: grid;
  place-items: center;
  box-shadow: 0 6px 16px rgba(0,0,0,0.1);
}

.about-illus img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.features li {
  display: flex;
  align-items: flex-start;   
  gap: 10px;                
}

.features li img {
  width: 28px;               
  height: 28px;
  object-fit: contain;
  flex-shrink: 0;            
  margin-top: 2px;           
}

.features li span {
  line-height: 1.5;
  color: var(--ink);
}


/* Testimonials */
.testi{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.quote{background:var(--white);border:1px solid color-mix(in oklab, var(--green-600) 15%, transparent);border-radius:18px;padding:18px;position:relative}
.quote::before{content:"\201C";position:absolute;left:12px;top:-22px;font-size:60px;color:var(--green-100)}

/* Pricing */
.pricing{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.price-card{background:var(--white);border:2px solid color-mix(in oklab, var(--green-600) 25%, transparent);border-radius:20px;padding:22px}
.price-card.pop{border-color:var(--green-600);box-shadow:0 30px 40px -32px rgba(64,185,60,.45)}
.price{font-size:clamp(1.6rem, 2.8vw, 2.2rem);font-weight:900}
.features{list-style:none;padding:0;margin:14px 0;display:grid;gap:8px}
.features li{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:start}

/* Image Strip */
.image-strip {
  text-align: center;
  margin-top: 60px;
  padding: 0 16px; 
}

.image-strip .image-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 15px; 
}

.image-strip img {
  width: 100%;
  height: 300px;
  object-fit: cover;
  display: block;
}

/* CTA under the images */
.strip-cta {
  margin-top: 32px;
  padding: 0 16px;
}

.strip-cta h2 {
  font-size: 1.8rem;
  margin-bottom: 12px;
  color: var(--ink);
}

.strip-cta .cta {
  padding: 12px 24px;
  font-size: 1rem;
}

/* Responsive adjustments */
@media (max-width: 900px) {
  .image-strip .image-row {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
}

@media (max-width: 600px) {
  .image-strip .image-row {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .image-strip img {
    height: 220px; /* smaller height for mobile */
  }

  .strip-cta h2 {
    font-size: 1.4rem;
  }
}


/* Contact */
.contact{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
form{display:grid;gap:12px}
input,textarea{padding:12px 14px;border-radius:12px;border:1px solid color-mix(in oklab, var(--green-600) 20%, transparent);font:inherit}
textarea{min-height:120px}
button[type="submit"]{cursor:pointer}

.contact-details ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}

.contact-details li {
  display: flex;
  align-items: center;
  gap: 10px; /* space between icon and text */
  font-size: 1rem;
  color: var(--ink);
}

.contact-details li img {
  width: 30px;     /* consistent size for all icons */
  height: auto;
  object-fit: contain;
  flex-shrink: 0;  /* prevents shrinking */
}

.contact-details a {
  color: var(--ink);
  text-decoration: none;
}

.contact-details a:hover {
  color: var(--green-600);
  text-decoration: underline;
}

/* Improved form styles */
.form-group {
  margin-bottom: 1rem;
}

label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 600;
}

input, textarea {
  width: 100%;
}

.required {
  color: var(--error);
}

.error-message {
  color: var(--error);
  font-size: 0.875rem;
  margin-top: 0.25rem;
  display: none;
}

/* Loading state for form */
.form-loading {
  opacity: 0.7;
  pointer-events: none;
}

/* Footer */
footer{padding:26px 0;border-top:1px solid color-mix(in oklab, var(--green-600) 20%, transparent);background:linear-gradient(180deg, #fff, var(--green-100))}

footer img {
  width: 24px;     /* icon size */
  height: 24px;    /* keep consistent */
  display: block;
  object-fit: contain;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

footer a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

footer a:hover img {
  transform: scale(1.15); /* subtle zoom on hover */
  opacity: 0.8;          /* fade effect */
}


/* Utilities */
.muted{color:var(--muted)}
.center{text-align:center}
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.show{opacity:1;transform:none}

/* Parallax hero background */
.hero::after{content:"";position:absolute;inset:auto 0 0 0;height:180px;background:radial-gradient(120% 80% at 50% 0%, color-mix(in oklab, var(--green-500) 8%, transparent), transparent)}

/* Responsive */
@media (max-width: 980px){
  .hero .container{grid-template-columns:1fr;gap:14px;padding:38px 0}
  .about{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .testi,.pricing{grid-template-columns:repeat(2,1fr)}
  .grid .card{grid-column:span 6}
  .menu{display:none}
  .burger{display:inline-block}
}
@media (max-width: 640px){
  .stats{grid-template-columns:1fr 1fr}
  .testi,.pricing{grid-template-columns:1fr}
  .grid .card{grid-column:span 12}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .leaf, .reveal, .card:hover, .cta:hover{animation:none;transition:none}
}

/* Fallbacks for older browsers */
@supports not (color: color-mix(in oklab, black, white)) {
  :root {
    --ring: 0 0 0 3px rgba(64, 185, 60, 0.3);
  }
  
  header {
    background: rgba(255, 255, 255, 0.9);
  }
  
  .mobile-panel a,
  .stat,
  .card,
  .about-illus,
  .quote,
  input,
  textarea {
    border-color: rgba(64, 185, 60, 0.15);
  }
  
  .cta {
    background: linear-gradient(135deg, #40b93c, #65c221);
  }
  
  .hero::after {
    background: radial-gradient(120% 80% at 50% 0%, rgba(128, 204, 40, 0.08), transparent);
  }
}