/* RESET & NORMALIZE */
html {box-sizing: border-box;}
*, *:before, *:after {box-sizing: inherit; margin:0; padding:0;}
html,body{height:100%;}
body{font-family:'Open Sans', Arial, sans-serif; font-size:16px; color:#245D36; background:#fff; line-height:1.6; -webkit-font-smoothing:antialiased;}
img{max-width:100%; height:auto; display:block;}
a{text-decoration:none; color:inherit; transition:color 0.2s;}
button,input,textarea,select{font:inherit; border:none; outline:none; background:none;}
ul,ol{list-style:none; margin:0; padding:0;}

/* BRAND COLORS */
:root {
  --primary: #245D36;
  --secondary: #F2F6F3;
  --accent: #8C460E;
  --neutral: #FFFFFF;
  --text-dark: #1a2b1a;
  --shadow: 0 2px 12px rgba(36,93,54,0.07);
  --radius: 12px;
}

/* TYPOGRAPHY */
h1,h2,h3,h4,h5,h6{
  font-family:'Montserrat',Arial,sans-serif;
  font-weight:700;
  color:var(--primary);
  line-height:1.15;
  margin-bottom:16px;
}
h1{font-size:2.5rem;margin-bottom:20px;}
h2{font-size:2rem;}
h3{font-size:1.25rem;}
h4{font-size:1.125rem;}
@media (max-width:700px){
  h1{font-size:2rem;}
  h2{font-size:1.5rem;}
  h3{font-size:1.125rem;}
}
p,li,blockquote{font-size:1rem; color:var(--text-dark); margin-bottom:16px;}
blockquote{font-style:italic; margin:0 0 8px 0; color:var(--primary);}
strong{font-weight:700;}

/* LAYOUT CONTAINERS */
.container {
  width:100%; max-width:1140px; margin:0 auto; padding:0 20px;
  display:flex; flex-direction:column; align-items:flex-start;
}
@media (max-width:1200px){
  .container{max-width:1000px;}
}
@media (max-width:900px){
  .container{max-width:700px;}
}
@media (max-width:700px){
  .container{padding:0 12px;}
}

.content-wrapper {
  display:flex; flex-direction:column; align-items:flex-start; gap:16px;
}

/* SECTIONS & SPACING */
.section {
  margin-bottom:60px;
  padding:40px 20px;
  background:var(--neutral);
}
.card-container{
  display:flex; flex-wrap:wrap; gap:24px;
}
.card{
  margin-bottom:20px;
  background:var(--secondary);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
  padding:32px 24px;
  position:relative;
  display:flex; flex-direction:column; gap:16px;
  transition:box-shadow 0.2s;
}
.card:hover{box-shadow:0 4px 24px rgba(36,93,54,0.11);}
.content-grid{
  display:flex; flex-wrap:wrap; gap:20px; justify-content:space-between;
}
.text-image-section{
  display:flex; align-items:center; gap:30px; flex-wrap:wrap;
}
.testimonial-card{
  display:flex; flex-direction:column; align-items:flex-start; gap:20px;
  padding:20px;
  background:var(--secondary);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
  margin-bottom:20px;
  max-width:600px;
  transition:box-shadow 0.2s;
}
.testimonial-card:hover{box-shadow:0 4px 24px rgba(36,93,54,0.11);}
.feature-item{
  display:flex; flex-direction:column; align-items:flex-start; gap:15px;
}
.text-section{margin-bottom:24px;}

/* BUTTONS & LINKS */
.btn-primary,
.btn-secondary{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:'Montserrat',Arial,sans-serif; font-weight:600;
  padding:12px 32px;
  border-radius:var(--radius);
  cursor:pointer;
  transition:background 0.2s,color 0.2s,box-shadow 0.2s,transform 0.1s;
  box-shadow:0 2px 8px rgba(36,93,54,0.04);
  font-size:1.1rem;
}
.btn-primary{
  background:var(--primary);
  color:var(--neutral);
  border:1.5px solid var(--primary);
}
.btn-primary:hover, .btn-primary:focus{
  background:var(--neutral);
  color:var(--primary);
  border-color:var(--primary);
  box-shadow:0 4px 18px rgba(36,93,54,0.13);
  text-decoration:none; transform:translateY(-1px);
}
.btn-secondary{
  background:var(--neutral);
  color:var(--primary);
  border:1.5px solid var(--primary);
}
.btn-secondary:hover, .btn-secondary:focus{
  background:var(--primary);
  color:var(--neutral);
  text-decoration:none; box-shadow:0 4px 18px rgba(36,93,54,0.10); transform:translateY(-1px);
}

/* HEADER */
header {
  background:var(--neutral);
  border-bottom:1px solid #e7ebe8;
  position:relative;
}
header .container {
  flex-direction:row; align-items:center; justify-content:space-between;
  padding:16px 20px; min-height:64px;
}
header nav {
  display:flex; flex-direction:row; align-items:center; gap:24px;
}
header nav a {
  color:var(--primary); font-family:'Montserrat',Arial,sans-serif; font-weight:500;
  padding:6px 0; opacity:0.90; position:relative; transition:color 0.15s,opacity 0.15s;
}
header nav a:hover, header nav a:focus {opacity:1; color:var(--accent);}
header .btn-primary{margin-left:26px;}

/* Hide mobile nav by default, show on mobile */
.mobile-menu-toggle {
  display:none; background:var(--neutral); color:var(--primary); font-size:2rem;
  padding:6px 16px; border-radius:var(--radius); border:1.5px solid #e7ebe8;
  cursor:pointer; margin-left:18px;
  transition: background 0.15s, color 0.15s;
}
.mobile-menu-toggle:focus,
.mobile-menu-toggle:hover { background:var(--secondary); color:var(--accent);}

.mobile-menu {
  display:none;
  position:fixed; left:0; top:0; width:100vw; height:100vh; z-index:3000;
  background:rgba(36,93,54,0.96);
  flex-direction:column; justify-content:flex-start; align-items:flex-start;
  transform:translateX(-100%);
  transition:transform 0.32s cubic-bezier(.53,.01,.32,1); /* slide effect */
}
.mobile-menu.open {
  display:flex;
  transform:translateX(0);
}
.mobile-menu-close {
  margin:20px; align-self:flex-end; font-size:2rem; color:var(--neutral);
  background:none; border:none; cursor:pointer;
  transition:color 0.16s,transform 0.1s;
}
.mobile-menu-close:hover,
.mobile-menu-close:focus {color:var(--accent); transform:scale(1.12);}
.mobile-nav{
  display:flex; flex-direction:column; gap:18px;
  width:100%; padding:60px 32px 32px 32px;
}
.mobile-nav a{
  color:var(--neutral); font-size:1.2rem; font-family:'Montserrat',Arial,sans-serif;
  padding:12px 5px; border-radius:var(--radius);
  transition: background 0.17s, color 0.17s;
}
.mobile-nav a:hover,
.mobile-nav a:focus{background:rgba(140,70,14,0.2); color:var(--accent);}

@media (max-width:980px){
  header .container nav,
  header .btn-primary{
    display:none;
  }
  .mobile-menu-toggle{
    display:block;
  }
}
@media (min-width:981px){
  .mobile-menu{display:none!important;}
  .mobile-menu-toggle{display:none;}
}

/* MAIN CONTENT & HERO */
main{flex:1; width:100%; background:var(--neutral);}
section{
  margin-bottom:60px;
  padding:40px 0;
  background:var(--neutral);
  display:flex;
  flex-direction:column;
  align-items:stretch;
  justify-content:center;
}
section:last-child{margin-bottom:0;}
@media (max-width:700px){
  section{padding:24px 0; margin-bottom:40px;}
}

/* SERVICE LIST FLEX */
.service-list{
  display:flex; flex-wrap:wrap; gap:24px; margin-bottom:20px; justify-content:flex-start;
}
.service-list>div{
  background:var(--secondary);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
  padding:24px 18px;
  display:flex; flex-direction:column; gap:12px;
  min-width:220px; flex:1 1 230px; max-width:320px;
}
.service-list>div h3{margin-bottom:8px; color:var(--accent); font-size:1.1rem;}
.service-list strong{color:var(--primary);}

/* Responsive flex containers */
@media (max-width:900px){
  .service-list, .content-grid, .card-container {
    flex-direction:column;
    gap:20px;
  }
  .card{
    min-width:unset; max-width:100%; width:100%;
  }
}

/* TESTIMONIALS */
.testimonial-card{
  color:var(--text-dark);
  background:var(--secondary);
  border:1px solid #E0E7E3;
  box-shadow:var(--shadow);
  margin-bottom:24px;
  padding:24px 22px;
  border-radius:var(--radius);
  max-width:550px;
  transition:box-shadow 0.19s;
  font-size:1rem;
}
.testimonial-card blockquote{
  color:var(--primary);
  font-size:1.07rem;
  border-left:3px solid var(--accent);
  padding-left:14px;
  margin-bottom:6px;
  font-style:italic;
}
.testimonial-card p {
  font-size:0.97rem; color:#555; margin-bottom:0;
}

/* HIGHLIGHT TEXTS */
.highlight{background:rgba(36,93,54,0.07);color:var(--accent);padding:3px 8px;border-radius:6px;}

/* OL AND UL STYLES */
ul,ol {
  margin:0 0 18px 20px;
  padding:0;
  display:flex; flex-direction:column; gap:10px;
}
ul li, ol li{
  position:relative;
  padding-left:22px;
  color:var(--text-dark);
  font-size:1rem;
}
ul li:before{
  content:'';
  width:8px;height:8px;
  background:var(--primary);
  border-radius:50%;
  position:absolute;left:0;top:8px;
  opacity:0.18;
}
ol li:before{
  content:counter(item)'.';
  color:var(--accent);
  left:0; top:0; position:absolute; font-weight:700;
}
ol{counter-reset:item;}
ol li{counter-increment:item;}

/* FOOTER */
footer{
  background:var(--secondary);
  border-top:1.5px solid #e7ebe8;
  padding:30px 0 15px 0;
  width:100%;
}
footer .container{
  flex-direction:row;
  align-items:flex-start;
  gap:40px;
}
footer img{width:50px; height:auto; margin-bottom:10px;}
footer .text-section{font-size:0.97rem; color:#5C2C06; line-height:1.5; margin-bottom:0;}
footer nav{display:flex; flex-direction:column; gap:6px;}
footer nav a{font-family:'Montserrat', Arial,sans-serif; font-size:1rem; color:var(--accent); opacity:0.82; padding:3px 0; transition:opacity 0.12s, color 0.13s;}
footer nav a:hover,footer nav a:focus{opacity:1; color:var(--primary);}
@media (max-width:900px){
  footer .container{flex-direction:column; gap:20px; align-items:flex-start;}
}

/* RESPONSIVE FLEX LAYOUTS */
@media (max-width:768px){
  .text-image-section {
    flex-direction:column;
    gap:20px;
    align-items:flex-start;
  }
  .content-grid,
  .service-list,
  .card-container{
    flex-direction:column;
    gap:20px;
  }
  section,
  .section{
    padding:24px 0 !important;
    margin-bottom:34px !important;
  }
}

/* MODALS & OVERLAYS (Cookie Banner) */
.cookie-banner {
  position:fixed; bottom:0; left:0; width:100vw; z-index:4000;
  background:var(--neutral);
  border-top:2px solid #e7ebe8;
  display:flex; flex-direction:row; align-items:center; justify-content:space-between;
  padding:18px 32px;
  box-shadow:0 -4px 24px rgba(36,93,54,0.07);
  transition:transform 0.28s cubic-bezier(.5,.1,.5,1), opacity 0.15s;
  opacity:1; transform:translateY(0);
  gap:24px;
}
.cookie-banner.hide {opacity:0; pointer-events:none; transform:translateY(100%);}
.cookie-banner .cookie-banner-message{
  font-size:1rem; color:var(--primary); font-family:'Open Sans', Arial, sans-serif; margin-right:24px; flex:1; min-width:0;
}
.cookie-banner .cookie-btns{
  display:flex; flex-direction:row; gap:14px; align-items:center;
}
.cookie-banner .btn-primary,
.cookie-banner .btn-secondary{
  padding:8px 26px; font-size:1rem; border-radius:var(--radius);
}
.cookie-banner .btn-settings{
  background:none;
  border:1.2px solid var(--primary);
  border-radius:var(--radius);
  color:var(--primary);
  font-weight:600;
  padding:8px 18px;
  margin-left:6px;
  cursor:pointer;
  font-family:'Montserrat',Arial,sans-serif;
  transition:background 0.16s, color 0.16s;
}
.cookie-banner .btn-settings:hover,
.cookie-banner .btn-settings:focus{background:var(--secondary); color:var(--accent);}
@media (max-width:700px){
  .cookie-banner{flex-direction:column; align-items:flex-start; gap:12px; padding:12px 10px;}
  .cookie-banner .btn-primary,.cookie-banner .btn-secondary,.cookie-banner .btn-settings{width:100%;}
}

/* Cookie Preferences Modal */
.cookie-modal-overlay{
  position:fixed; z-index:5000; top:0; left:0; width:100vw; height:100vh;
  background:rgba(28,42,30,0.38);
  display:none; align-items:center; justify-content:center;
  transition:opacity 0.20s;
}
.cookie-modal-overlay.open {display:flex;}
.cookie-modal {
  background:var(--neutral);
  border-radius:var(--radius);
  box-shadow:0 12px 54px rgba(36,93,54,0.08);
  padding:40px 28px 32px 28px;
  min-width:320px;
  max-width:96vw;
  display:flex; flex-direction:column; gap:18px;
  animation:fadeInModal 0.35s cubic-bezier(.59,.02,.37,1);
}
@keyframes fadeInModal { 0%{opacity:0; transform:translateY(40px);}100%{opacity:1;transform:translateY(0);}}
.cookie-modal h3{font-size:1.3rem; margin-bottom:8px; color:var(--primary);}
.cookie-category{
  margin-bottom:10px; display:flex; align-items:center; gap:8px;
}
.cookie-toggle {
  width:38px; height:22px; background:var(--secondary); border-radius:11px; position:relative; flex-shrink:0; border:1px solid #e0e7e3; transition:background 0.18s;
  margin-left:9px;
}
.cookie-toggle input[type="checkbox"] {
  opacity:0; width:38px; height:22px; position:absolute; left:0; top:0; margin:0; cursor:pointer;
}
.cookie-toggle .slider {
  position:absolute; top:2px; left:3px; width:16px; height:16px;
  background:var(--primary); border-radius:50%; transition:left 0.22s, background 0.13s;
}
.cookie-toggle input:checked + .slider {left:17px;background:var(--accent);}
/* Disable toggle for essential cookies */
.cookie-category.essential .cookie-toggle{background:#e4edea; border-color:#c6d8cd;}
.cookie-category.essential .slider{background:var(--primary)!important;}
.cookie-toggle input:disabled + .slider{opacity:0.50;}
.cookie-modal .modal-actions{
  display:flex; flex-direction:row; gap:16px; justify-content:flex-end; margin-top:8px;
}
.cookie-modal .btn-primary, .cookie-modal .btn-secondary {padding:8px 26px;}
@media(max-width:540px){.cookie-modal{padding:18px 8px;}}

/* ANIMATIONS - only on menu & banner */
@media (prefers-reduced-motion: no-preference) {
  .mobile-menu,
  .cookie-banner,
  .cookie-modal{
    transition:all 0.25s cubic-bezier(.59,.02,.37,1);
  }
}

/* GENERAL MICRO-INTERACTIONS */
a,button,[tabindex]{outline:none;transition:box-shadow 0.12s, color 0.11s;}
a:focus-visible, button:focus-visible{box-shadow:0 0 0 3px #cfdecf;}

/* MISC: Accessibility Helpers */
[hidden], .hidden{display:none!important;}

/* CUSTOM FORM ELEMENTS (for modal toggles) */
input[type="checkbox"] {accent-color: var(--primary);}

/* REMOVE SCROLL SHADOW WHEN MODAL/BANNER OPEN */
body.menu-open, body.cookie-modal-open{overflow:hidden;}

/* VISUAL HIERARCHY HELPERS */
.section > .container > h2, .section > .container > h1{margin-bottom:18px;}
.section > .container {padding:0;}

/* VISIBILITY HELPERS (JS will add .open or .hide) */
.mobile-menu{display:none;}
.mobile-menu.open{display:flex;}
.cookie-modal-overlay{display:none;}
.cookie-modal-overlay.open{display:flex;}

/* FIN: No grid or columns, all FLEXBOX layouts only */
