:root {
  --primary: #5f7a61;
  --secondary: #d4a373;
  --accent: #e29578;
  --background: #fffaf4;
  --surface: #ffffff;
  --ink: #2b2d42;
  --muted: #6d6875;
  --border: #e9edc9;
  --font-heading: 'Bricolage Grotesque', sans-serif;
  --font-accent: 'Caveat', cursive;
  --font-body: 'Plus Jakarta Sans', sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
body{
  margin:0;
  color:var(--ink);
  font-family:var(--font-body);
  line-height:1.7;
  background-color: var(--background);
}
h1,h2,h3{margin:0;font-family:var(--font-heading);line-height:1.1; letter-spacing: -0.02em;}
h1{font-size:clamp(2.8rem,7vw,4.5rem); color: var(--primary);}
h2{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:1.2rem; color: var(--primary);}
h3{font-size:1.4rem;margin-bottom:.5rem; color: var(--ink);}
p{margin-top:0;}
a{color:inherit; text-decoration: none;}
img{max-width:100%;display:block;}

.handwritten {
  font-family: var(--font-accent);
  font-size: 1.5rem;
  color: var(--accent);
}

.container{width:100%;max-width:1100px;margin-inline:auto;padding-inline:24px}
.section{padding-block:clamp(3.5rem,8vw,6rem)}

.card{
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: 28px;
  padding: 36px;
  transition: 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.card:hover {
  transform: translateY(-6px) rotate(0.5deg);
  border-color: var(--accent);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  font-weight:700;
  border-radius:99px;
  padding:0.9rem 2.2rem;
  transition: 0.3s;
  font-family: var(--font-body);
  border: none;
  cursor: pointer;
  font-size: 0.95rem;
}
.btn-primary{
  background: var(--primary);
  color:#fff;
  box-shadow: 0 8px 20px rgba(95, 122, 97, 0.2);
}
.btn-primary:hover {
  background: #4d6650;
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(95, 122, 97, 0.3);
}
.btn-secondary{
  background: var(--surface);
  color: var(--ink);
  border: 2px solid var(--border);
}
.btn-secondary:hover{
  border-color: var(--accent);
  color: var(--accent);
}

/* Header */
.site-header{
  position: sticky;
  top: 0;
  background: rgba(255, 250, 244, 0.88);
  backdrop-filter: blur(12px);
  z-index: 100;
  border-bottom: 1px solid var(--border);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;min-height:80px}
.site-logo{font-family:var(--font-heading);font-weight:800;font-size:1.5rem; color: var(--primary); display: flex; align-items: center; gap: 8px;}

.nav-menu{display:flex;gap:28px; align-items: center;}
.nav-menu a{font-weight:700;color:var(--ink); font-size: 0.92rem;}
.nav-menu a:not(.btn):not(.nav-cta):hover{color:var(--accent)}

.nav-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--ink);padding:8px;}

/* Canvas */
.hero-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

/* Grids */
.grid-3{display:grid;gap:28px;grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-2{display:grid;gap:40px;grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-4{display:grid;gap:24px;grid-template-columns:repeat(4,minmax(0,1fr))}

/* Pill */
.pill{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 16px;
  border-radius: 99px;
  font-weight: 700;
  font-size: 0.82rem;
}

/* Accordion */
.accordion-toggle{
  width:100%;
  background:var(--surface);
  border:2px solid var(--border);
  border-radius:20px;
  padding:20px 24px;
  font-size:1.05rem;
  font-weight:700;
  font-family:var(--font-heading);
  color:var(--ink);
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  align-items:center;
  transition:0.2s;
  text-align:left;
}
.accordion-toggle:hover{border-color:var(--accent);color:var(--accent)}
.accordion-toggle.open{border-color:var(--accent);color:var(--accent);border-radius:20px 20px 0 0;border-bottom:none;}
.accordion-content{
  display:none;
  background:var(--surface);
  border:2px solid var(--accent);
  border-top:none;
  border-radius:0 0 20px 20px;
  padding:0 24px 20px;
  color:var(--muted);
  line-height:1.7;
}
.accordion-content.open{display:block}

/* Footer */
.site-footer a:hover{color:var(--accent)!important}

@media (max-width:850px){
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  .nav-menu{display:none;}
  .nav-menu.active{
    display:flex;
    flex-direction:column;
    position:absolute;
    top:100%;left:0;right:0;
    background:var(--background);
    padding:24px;
    border-bottom:1px solid var(--border);
    box-shadow:0 12px 24px rgba(0,0,0,0.06);
  }
  .nav-toggle{display:block}
}

/* Header CTA contrast fix: btn-primary */
.site-header .nav-menu .btn-primary,
.site-header .nav-menu .btn-primary:hover {
  color: #fff !important;
}
