/* Reset and base */
* { margin: 0; padding: 0; box-sizing: border-box; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
:root{
  /* Palette */
  --primary: #2A9D5A;
  --primary-600: #238a4a;
  --accent: #f5a623;
  --muted: #8a8a8a;
  --text: #222222;
  --neutral: #f7f7f8;
  --card-bg: #ffffff;
  --glass: rgba(255,255,255,0.72);
  --elev-1: 0 6px 18px rgba(20,20,20,0.06);
  --elev-2: 0 10px 30px rgba(20,20,20,0.08);
  --radius-lg: 14px;
  --radius-md: 10px;
  --radius-sm: 8px;

  /* Typography scale */
  --fs-hero: 2.6rem;
  --fs-h1: 1.8rem;
  --fs-h2: 1.4rem;
  --fs-body: 1rem;
  --line-height: 1.6;

  /* Motion */
  --ease: cubic-bezier(.2,.9,.2,1);
  --fast: 160ms;
  --med: 280ms;
}

/* Base typography and layout */
html { font-size: 16px; }
body {
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  color: var(--text);
  background: linear-gradient(180deg, #fbfbfb 0%, var(--neutral) 100%);
  line-height: var(--line-height);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Utility container */
.container { max-width:1200px; margin:0 auto; padding:0 1rem; }

/* Header and navigation */
header { background: rgba(255,255,255,0.9); border-bottom: 1px solid rgba(20,20,20,0.04); position: sticky; top: 0; z-index: 60; backdrop-filter: blur(6px); }
nav { display:flex; align-items:center; justify-content:space-between; padding:1rem 0; gap:1rem; }
.logo-link { display:flex; align-items:center; text-decoration:none; line-height:0; }
.site-logo {
  width:auto;
  height:96px;
  max-height:140px;
  display:block;
  object-fit:contain;
  transition:height var(--med) var(--ease);
}

/* Navigation items */
nav ul { list-style:none; display:flex; gap:1.25rem; align-items:center; margin-left:1rem; }
nav a { color:var(--text); text-decoration:none; padding:0.35rem 0.5rem; transition:color var(--fast) var(--ease), transform var(--fast) var(--ease); font-weight:600; font-size:0.98rem; }
nav a:hover, nav a:focus { color:var(--primary); transform:translateY(-1px); outline:none; }
.cta {
  background: linear-gradient(180deg,var(--primary),var(--primary-600));
  color:#fff;
  padding:0.55rem 1rem;
  border-radius:10px;
  box-shadow: 0 6px 18px rgba(42,157,90,0.18);
  transition: transform var(--fast) var(--ease), box-shadow var(--fast) var(--ease), opacity var(--fast) var(--ease);
  font-weight:700;
}
.cta:hover { transform:translateY(-3px); box-shadow: 0 12px 30px rgba(42,157,90,0.14); }

/* Accessibility focus */
a:focus, button:focus, .logo-link:focus {
  outline: 3px solid rgba(42,157,90,0.18);
  outline-offset: 4px;
  border-radius:8px;
}

/* Hero */
.hero { position:relative; padding:5rem 1rem; overflow:hidden; min-height:420px; display:flex; align-items:center; justify-content:center; }
.hero-bg { position:absolute; inset:0; background-position:center; background-size:cover; filter:brightness(0.48) saturate(0.95); z-index:0; transform:scale(1.02); transition:transform 8s linear; }
.hero:hover .hero-bg { transform:scale(1.04); }
.hero-content { position:relative; z-index:2; max-width:980px; margin:0 auto; text-align:center; color:#fff; padding:1rem; }
.hero h1 { font-size:var(--fs-hero); line-height:1.02; margin-bottom:0.6rem; font-weight:700; letter-spacing:-0.02em; text-shadow: 0 6px 18px rgba(0,0,0,0.35); }
.hero p { font-size:1.05rem; margin-bottom:1.25rem; color:rgba(255,255,255,0.92); max-width:760px; margin-left:auto; margin-right:auto; }
.btn, .hero .btn {
  background: linear-gradient(180deg,var(--primary),var(--primary-600));
  color:#fff;
  padding:0.85rem 1.4rem;
  border-radius:12px;
  text-decoration:none;
  display:inline-block;
  font-weight:700;
  box-shadow: 0 10px 30px rgba(42,157,90,0.12);
  transition: transform var(--fast) var(--ease), box-shadow var(--fast) var(--ease);
}
.btn:hover { transform:translateY(-4px); box-shadow: 0 18px 40px rgba(42,157,90,0.12); }

/* Section headings */
h2 { font-size:var(--fs-h1); margin-bottom:1rem; font-weight:700; color:var(--text); }
.section-sub { color:var(--muted); margin-bottom:1.25rem; font-size:0.98rem; }

/* Services */
.services { padding:3.25rem 1rem; max-width:1200px; margin:0 auto; text-align:center; }
.services h2 { font-size:1.9rem; }
.card-grid { display:flex; gap:1.5rem; justify-content:center; flex-wrap:wrap; margin-top:1.25rem; }
.card {
  background: linear-gradient(180deg, rgba(255,255,255,0.98), var(--card-bg));
  padding:1.5rem;
  border-radius:var(--radius-lg);
  width:320px;
  box-shadow: var(--elev-1);
  text-align:left;
  transition: transform var(--med) var(--ease), box-shadow var(--med) var(--ease);
  border: 1px solid rgba(20,20,20,0.03);
}
.card:hover { transform:translateY(-8px); box-shadow: var(--elev-2); }
.card-image { height:170px; overflow:hidden; border-radius:10px; margin-bottom:1rem; background:linear-gradient(180deg,#f3f3f3,#fff); }
.card-image img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 6s linear; }
.card:hover .card-image img { transform:scale(1.06); }
.card h3 { margin-bottom:0.5rem; font-size:1.05rem; font-weight:700; }
.card p { margin-bottom:1rem; color:#555; font-size:0.98rem; }

/* Testimonials */
.testimonials { padding: 3rem 1rem; background: linear-gradient(180deg,#fff,#fbfbfb); border-radius: 14px; max-width:1200px; margin:2rem auto; box-shadow: var(--elev-2); }
.testimonials .container { padding: 0 1rem; }
.testimonials h2 { text-align:center; font-size:1.8rem; margin-bottom:0.25rem; }
.testimonials .sub { text-align:center; color:var(--muted); margin-bottom:1.25rem; }
.testimonials-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:1.25rem; }
.testimonial-card {
  display:flex; gap:1rem; align-items:flex-start; padding:1rem; border-radius:12px;
  background: linear-gradient(180deg, rgba(255,255,255,0.9), rgba(250,250,250,0.9));
  box-shadow: 0 6px 18px rgba(20,20,20,0.03);
  border:1px solid rgba(20,20,20,0.03);
}
.testimonial-photo { width:84px; height:84px; flex-shrink:0; border-radius:12px; overflow:hidden; }
.testimonial-photo img { width:100%; height:100%; object-fit:cover; display:block; }
.testimonial-body h3 { margin:0 0 0.25rem 0; font-size:1rem; font-weight:700; }
.testimonial-body .location { margin:0 0 0.5rem 0; color:var(--muted); font-size:0.9rem; }
.testimonial-body .rating { color: var(--accent); font-size:1rem; margin-bottom:0.5rem; }
.testimonial-body .quote { color:#444; font-size:0.95rem; line-height:1.45; }

/* Resources CTA */
.resources-cta { padding:2.25rem 1rem; max-width:1200px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.resources-hero { border-radius:12px; max-height:420px; object-fit:cover; width:100%; }

/* Services detail */
.services-detail .services-hero { height:240px; background-position:center; background-size:cover; filter:brightness(0.6); border-radius:12px; margin:1rem auto; max-width:1200px; }
.services-wrap { max-width:1200px; margin:1.5rem auto; padding:0 1rem; }
.service-article { display:flex; gap:1rem; align-items:flex-start; margin-bottom:1.5rem; background:#fff; padding:1rem; border-radius:12px; box-shadow:0 8px 24px rgba(20,20,20,0.04); border:1px solid rgba(20,20,20,0.03); }
.service-thumb { width:220px; flex-shrink:0; }
.service-thumb img { width:100%; height:140px; object-fit:cover; border-radius:10px; }
.service-text h2 { margin-bottom:0.5rem; font-size:1.1rem; }

/* About */
.about { padding:2.5rem 1rem; max-width:1200px; margin:0 auto; }
.about-grid { display:flex; gap:1.5rem; align-items:center; flex-wrap:wrap; }
.about-image { flex:1; min-width:260px; }
.about-content { flex:2; min-width:260px; }
.cred-list { margin-top:1rem; list-style:none; color:#444; display:flex; gap:1rem; flex-wrap:wrap; }

/* Resources list */
.resource-list { display:flex; gap:1rem; flex-wrap:wrap; margin-top:1rem; }
.resource-card {
  background: linear-gradient(180deg,#fff,#fbfbfb);
  padding:1rem 1.25rem; border-radius:12px; text-decoration:none; color:var(--text);
  box-shadow: 0 8px 24px rgba(20,20,20,0.04); border:1px solid rgba(20,20,20,0.03);
  transition: transform var(--med) var(--ease), box-shadow var(--med) var(--ease);
}
.resource-card:hover { transform:translateY(-6px); box-shadow: 0 18px 40px rgba(20,20,20,0.06); }

/* FAQ */
.faq { padding:2.5rem 1rem; max-width:900px; margin:0 auto; }
.faq-item { background:#fff; padding:1rem; border-radius:12px; margin-bottom:1rem; box-shadow:0 8px 24px rgba(20,20,20,0.04); border:1px solid rgba(20,20,20,0.03); }

/* Contact */
.contact { padding:2.5rem 1rem; max-width:1100px; margin:0 auto; }
.contact-grid { display:flex; gap:2rem; flex-wrap:wrap; align-items:flex-start; }
.contact-form { flex:1; min-width:300px; background:linear-gradient(180deg,#fff,#fbfbfb); padding:1.25rem; border-radius:12px; box-shadow:0 8px 24px rgba(20,20,20,0.04); display:flex; flex-direction:column; gap:0.75rem; border:1px solid rgba(20,20,20,0.03); }
.contact-info { flex:1; min-width:260px; background:linear-gradient(180deg,#fff,#fbfbfb); padding:1.25rem; border-radius:12px; box-shadow:0 8px 24px rgba(20,20,20,0.04); border:1px solid rgba(20,20,20,0.03); }
label { font-weight:700; font-size:0.95rem; color:var(--text); }
input, textarea {
  padding:0.85rem; border:1px solid rgba(20,20,20,0.06); border-radius:10px; width:100%;
  background: #fff; transition: box-shadow var(--fast) var(--ease), border-color var(--fast) var(--ease);
}
input:focus, textarea:focus { box-shadow: 0 6px 18px rgba(42,157,90,0.08); border-color: rgba(42,157,90,0.18); outline:none; }
textarea { min-height:140px; resize:vertical; }
button { background: linear-gradient(180deg,var(--primary),var(--primary-600)); color:#fff; padding:0.85rem; border:none; border-radius:10px; cursor:pointer; font-weight:700; transition: transform var(--fast) var(--ease); }
button:hover { transform:translateY(-3px); }

/* Images */
.img-responsive { width:100%; height:auto; display:block; border-radius:10px; object-fit:cover; }

/* Footer */
footer { background:#fff; text-align:center; padding:1.25rem; margin-top:2rem; border-top:1px solid rgba(20,20,20,0.04); color:var(--muted); font-size:0.95rem; }

/* Small UI micro-interactions */
a, button, .card, .resource-card { will-change: transform; -webkit-tap-highlight-color: transparent; }

/* Responsive adjustments */
@media (max-width:1200px) {
  .site-logo { height:72px; }
  :root { --fs-hero: 2.2rem; }
}
@media (max-width:900px) {
  nav { padding:0.75rem 0; gap:0.5rem; }
  .site-logo { height:56px; }
  .card-grid { gap:1rem; justify-content:stretch; }
  .testimonials-grid { grid-template-columns: repeat(2, 1fr); }
  :root { --fs-hero: 1.9rem; --fs-h1: 1.6rem; }
}
@media (max-width:640px) {
  .site-logo { height:44px; }
  nav ul { gap:0.6rem; margin-left:0.5rem; }
  .hero { padding:3rem 1rem; min-height:320px; }
  .hero h1 { font-size:1.6rem; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .testimonial-photo { width:72px; height:72px; }
  .card { width:100%; }
  .resources-cta { flex-direction:column; align-items:stretch; gap:1rem; }
}

/* Optional small helpers for improved accessibility and conversion */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.focus-ring { box-shadow: 0 0 0 4px rgba(42,157,90,0.12); border-radius:8px; outline:none; }

/* End of stylesheet */