
/* === Modern Refresh — Polished Light Theme ==================================
   - White background, elevated cards, clean nav
   - Reusable utilities (spacing, layout, text)
   - Components: buttons, badges, callouts, checklist, tables, forms
   - Responsive + accessible, minimal JS hooks
   ========================================================================== */

:root{
  --bg: #ffffff;
  --panel: #ffffff;
  --surface: #f8fafc;              /* section alt bg */
  --text: #111827;                 /* slate-900 */
  --muted: #475467;                /* slate-600 */
  --accent: #166534;               /* primary brand accent */
  --accent-2: #16a34a;             /* secondary accent */
  --ring: rgba(22,163,74,.30);
  --radius: 14px;
  --shadow: 0 8px 28px rgba(16,24,40,.08);
  --gap: clamp(16px, 2.2vw, 24px);
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important}
}
body{
  margin:0;
  background: var(--bg);
  color:var(--text);
  font: 500 16px/1.65 ui-sans-serif, system-ui, -apple-system, "Segoe UI",
        Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji",
        "Segoe UI Emoji", "Segoe UI Symbol";
  letter-spacing:.2px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Type scale */
h1,h2,h3,h4{line-height:1.15;margin:0 0 .6em}
h1{font-size:clamp(34px,4.4vw,46px);font-weight:800;letter-spacing:-.02em}
h2{font-size:clamp(26px,3.2vw,36px);font-weight:750;letter-spacing:-.01em}
h3{font-size:clamp(20px,2.5vw,28px);font-weight:700}
p{margin:.5em 0 1em;color:var(--muted)}
small,.text-sm{font-size:.9rem;color:var(--muted)}

/* Images & media */
img,svg,video{max-width:100%;height:auto;border-radius:12px}

/* Layout helpers */
.container{max-width:1180px;margin:0 auto;padding:calc(var(--gap) + 6px);}
.container.narrow{max-width:860px}
.section{padding: clamp(42px, 6vw, 72px) 0}
.section.alt{background: var(--surface)}

/* Grid */
.grid{display:grid;gap:var(--gap)}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width: 1024px){.grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 860px){
  .grid.cols-3,.grid.cols-2,.grid.cols-4{grid-template-columns:1fr}
}

/* Cards */
.card{
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: clamp(16px, 2vw, 22px);
}
.card:hover{box-shadow: 0 10px 34px rgba(16,24,40,.10)}

/* Hero */
.hero{padding: clamp(58px, 8vw, 120px) 0}
.hero h1{margin-bottom:.25em}
.hero .subtext{font-size:clamp(16px,2.2vw,20px);color:var(--muted);max-width:52ch}
.hero .actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}

/* Buttons */
button, .btn, input[type=button], input[type=submit]{
  appearance:none;
  border:1px solid #e5e7eb;
  background: linear-gradient(180deg, rgba(34,197,94,.10), rgba(34,197,94,.06));
  color: #111827;
  font-weight: 700;
  padding: 12px 18px;
  border-radius: 12px;
  cursor:pointer;
  transition: transform .08s ease, box-shadow .2s ease, background .2s ease;
  box-shadow: 0 6px 16px rgba(34,197,94,.12);
  text-decoration:none;
  display:inline-flex;align-items:center;gap:10px;
}
button:hover,.btn:hover{transform: translateY(-1px)}
button:focus-visible,.btn:focus-visible{outline:3px solid var(--ring);outline-offset:2px}
.btn.primary{background: linear-gradient(180deg, var(--accent), color-mix(in oklab, var(--accent), white 18%)); color:#fff; border-color:transparent; box-shadow: 0 8px 18px color-mix(in oklab, var(--accent), black 20% / .25)}
.btn.secondary{background:#fff;border-color:#e5e7eb;color:#111827}
.btn.ghost{background:transparent;border-color:#e5e7eb;color:#111827;box-shadow:none}
.btn.sm{padding:9px 12px;border-radius:10px;font-weight:600}
.btn.lg{padding:14px 22px;border-radius:14px;font-size:1.05rem}

/* Badges & Pills */
.badge{display:inline-block;font-weight:700;background:#ecfdf5;color:#14532d;border:1px solid #bbf7d0;padding:4px 10px;border-radius:999px;font-size:.8rem}
.pill{display:inline-block;background:#f1f5f9;color:#111827;padding:6px 12px;border-radius:999px}

/* Callout */
.callout{border:1px solid #e5e7eb;background:#f8fafc;border-radius:12px;padding:14px 16px}
.callout.success{background:#ecfdf5;border-color:#a7f3d0}
.callout.warn{background:#fffbeb;border-color:#fde68a}
.callout.danger{background:#fef2f2;border-color:#fecaca}

/* Lists */
ul.checklist{list-style:none;padding-left:0}
ul.checklist li{position:relative;padding-left:28px;margin:8px 0}
ul.checklist li::before{content:"✓";position:absolute;left:0;top:0.15em;font-weight:800;color:var(--accent)}

/* Forms */
label{display:block;font-weight:700;margin:10px 0 6px}
input, select, textarea{
  width:100%;
  background: #fff;
  color: var(--text);
  border:1px solid #e5e7eb;
  border-radius: 12px;
  padding: 12px 14px;
  outline:none;
  transition: box-shadow .2s ease, border-color .2s ease;
}
input:focus, select:focus, textarea:focus{
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--ring);
}
input[type=checkbox],input[type=radio]{width:auto}

/* Nav */
.nav{
  display:flex;align-items:center;gap:14px;
  background: #ffffff;
  border-bottom:1px solid #e5e7eb;
  padding:12px 16px;
  position:sticky;top:0;z-index:50;
  transition: box-shadow .2s ease, border-color .2s ease, background .2s ease;
}
.nav.is-scrolled{box-shadow: 0 10px 24px rgba(17,24,39,.06)}
.nav a{
  color: var(--muted); text-decoration:none; padding:8px 12px; border-radius:10px
}
.nav a:hover{background: #f2f4f7; color:#111827}
.nav .nav-menu{display:flex;gap:6px;flex-wrap:wrap}
.nav .nav-menu.open{display:flex}
@media (max-width:760px){
  .nav .nav-menu{display:none;flex-direction:column;gap:4px;margin-top:8px}
  .nav .nav-menu.open{display:flex}
}

/* Tables */
table{width:100%;border-collapse:separate;border-spacing:0 8px}
thead th{color:#667085;text-align:left;font-weight:700;font-size:.9rem;padding:8px 10px}
tbody td{
  background: #fafafa;
  border:1px solid #e5e7eb;
  padding:10px 12px;
}
tbody tr td:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}
tbody tr td:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}

/* Links */
a{color:var(--accent);text-underline-offset:3px}
a:hover{filter:brightness(1.1)}

/* Utilities */
.round{border-radius:var(--radius)}
.shadow{box-shadow:var(--shadow)}
.center{text-align:center}
.muted{color:var(--muted)}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.mt-4{margin-top:4px}.mb-4{margin-bottom:4px}
.mt-8{margin-top:8px}.mb-8{margin-bottom:8px}
.mt-16{margin-top:16px}.mb-16{margin-bottom:16px}
.mt-24{margin-top:24px}.mb-24{margin-bottom:24px}
.mt-32{margin-top:32px}.mb-32{margin-bottom:32px}

/* Print */
@media print{
  .nav{position:static;border-bottom:0}
  .btn,.nav a{filter:grayscale(1)}
}


/* === Contact page: attached cards ======================================== */
.contact-wrap{display:grid;grid-template-columns:1.05fr 1.35fr;gap:0}
.contact-wrap .card{margin:0;border-radius:0}
.contact-wrap .card:first-child{border-top-left-radius:var(--radius);border-bottom-left-radius:var(--radius);border-right-width:0}
.contact-wrap .card:last-child{border-top-right-radius:var(--radius);border-bottom-right-radius:var(--radius)}
@media (max-width: 860px){
  .contact-wrap{grid-template-columns:1fr}
  .contact-wrap .card{border-radius:var(--radius);border-right-width:1px}
  .contact-wrap .card + .card{margin-top:-1px}
}

/* Green details card */
.card.contact-details{background:var(--accent);color:#fff;border-color:var(--accent)}
.card.contact-details a{color:#d1fae5}
.card.contact-details .muted{color:#e6ffe6}

/* Keep form card white */
.card.contact-form{background:#fff}

/* === Scoped hover: only on Home & Services =============================== */
.page-home .card.hoverable:hover,
.page-services .card.hoverable:hover{
  background: var(--accent);
  color:#fff;
  border-color: var(--accent);
  transform: translateY(-2px);
}
.page-home .card.hoverable:hover .muted,
.page-services .card.hoverable:hover .muted{color:#e6ffe6}
.page-home .card.hoverable:hover a,
.page-services .card.hoverable:hover a{color:#d1fae5}


/* === Hover color fix for headings/text (Home & Services only) ============ */
.page-home .card.hoverable:hover,
.page-home .card.hoverable:hover h1,
.page-home .card.hoverable:hover h2,
.page-home .card.hoverable:hover h3,
.page-home .card.hoverable:hover h4,
.page-home .card.hoverable:hover h5,
.page-home .card.hoverable:hover h6,
.page-home .card.hoverable:hover p,
.page-home .card.hoverable:hover li,
.page-home .card.hoverable:hover small,
.page-home .card.hoverable:hover strong,
.page-home .card.hoverable:hover span,
.page-home .card.hoverable:hover summary,
.page-services .card.hoverable:hover,
.page-services .card.hoverable:hover h1,
.page-services .card.hoverable:hover h2,
.page-services .card.hoverable:hover h3,
.page-services .card.hoverable:hover h4,
.page-services .card.hoverable:hover h5,
.page-services .card.hoverable:hover h6,
.page-services .card.hoverable:hover p,
.page-services .card.hoverable:hover li,
.page-services .card.hoverable:hover small,
.page-services .card.hoverable:hover strong,
.page-services .card.hoverable:hover span,
.page-services .card.hoverable:hover summary{
  color:#fff !important;
}


/* === Contact details: fill remaining space with map ====================== */
.contact-wrap{align-items:stretch}
.contact-wrap .card{height:100%}
.card.contact-details{display:flex;flex-direction:column}
.card.contact-details .map{flex:1;min-height:280px}
.card.contact-details .map iframe{width:100%;height:100%}
