:root{
  --green:     #1a6b3a;
  --green-dark:#0d4b26;
  --green-mid: #2d8a52;
  --lime:      #c8de16;
  --lime-dark: #a8b800;
  --wood:      #e8c99a;
  --bg:        #f4f8f1;
  --bg-muted:  #e8f0e2;
  --panel:     #ffffff;
  --text:      #1a2e1f;
  --muted:     #5a7a63;
  --border:    rgba(26,107,58,.14);
}

*{box-sizing:border-box;}

body{
  background:var(--bg);
  color:var(--text);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}

a{color:inherit;text-decoration:none;}

/* ── HEADER ───────────────────────────────────── */
.landing-header{
  position:sticky;
  top:0;
  z-index:100;
  background:var(--green);
  box-shadow:0 2px 16px rgba(13,75,38,.30);
}

.brand{ min-width:auto; }

.brand-logo{
  height:52px;
  width:auto;
  display:block;
  filter:drop-shadow(0 1px 3px rgba(0,0,0,.25));
}

.landing-nav a{
  font-size:14px;
  color:rgba(255,255,255,.88);
  font-weight:500;
  transition:color .15s;
}
.landing-nav a:hover{ color:#fff; }

.search .form-control{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.20);
  color:#fff;
}
.search .form-control::placeholder{ color:rgba(255,255,255,.60); }
.search .btn-warning{
  background:var(--lime);
  border-color:var(--lime);
  color:var(--green-dark);
  font-weight:700;
}
.search .btn-warning:hover{
  background:var(--lime-dark);
  border-color:var(--lime-dark);
}

/* ── HERO ─────────────────────────────────────── */
.hero{ padding:36px 0 10px; }

.hero-card{
  border-radius:20px;
  overflow:hidden;
  background:linear-gradient(120deg, var(--green-dark) 0%, var(--green) 55%, var(--green-mid) 100%);
  border:2px solid rgba(200,222,22,.18);
  min-height:280px;
  display:flex;
  box-shadow:0 8px 40px rgba(13,75,38,.20);
}

.hero-copy{ padding:32px; flex:1 1 55%; }

.hero-title{
  font-size:34px;
  font-weight:900;
  line-height:1.05;
  text-transform:uppercase;
  color:#fff;
}
.hero-title span{ color:var(--lime); }

.hero-text{
  margin-top:10px;
  color:rgba(255,255,255,.85);
  max-width:520px;
}

.hero-carousel{ flex:1 1 45%; min-height:280px; position:relative; }
.hero-carousel .carousel,
.hero-carousel .carousel-inner,
.hero-carousel .carousel-item{ height:100%; }
.hero-carousel img{
  height:280px;
  width:100%;
  object-fit:contain;
  object-position:center;
  background:rgba(255,255,255,.06);
}

/* btn overrides in hero */
.hero-copy .btn-danger{
  background:var(--lime);
  border-color:var(--lime);
  color:var(--green-dark);
  font-weight:700;
}
.hero-copy .btn-danger:hover{ background:var(--lime-dark); border-color:var(--lime-dark); }
.hero-copy .btn-outline-light{ border-color:rgba(255,255,255,.55); color:#fff; }
.hero-copy .btn-outline-light:hover{ background:rgba(255,255,255,.12); }

/* ── SECTIONS ─────────────────────────────────── */
.section{ padding:32px 0; }

.section-muted{
  background:var(--bg-muted);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}

.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  margin-bottom:16px;
}

.section-title{
  font-size:22px;
  font-weight:800;
  margin:0;
  color:var(--green-dark);
}

.section-sub{ color:var(--muted); font-size:13px; }

.section-link{
  color:var(--green);
  font-weight:700;
  font-size:13px;
}
.section-link:hover{ color:var(--green-dark); }

/* ── DEPARTAMENTOS ────────────────────────────── */
.dept-card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:14px;
  padding:14px 10px;
  text-align:center;
  height:100%;
  transition:box-shadow .15s,transform .15s;
}
.dept-card:hover{
  box-shadow:0 4px 18px rgba(26,107,58,.14);
  transform:translateY(-2px);
}

.dept-icon{
  width:48px;
  height:48px;
  border-radius:14px;
  margin:0 auto 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(26,107,58,.10);
  color:var(--green);
  font-size:24px;
}

.dept-name{
  font-size:12px;
  font-weight:800;
  color:var(--text);
}

/* ── PROMOÇÕES ────────────────────────────────── */
.promo-card{
  background:linear-gradient(135deg, var(--green-dark), var(--green));
  border:2px solid rgba(200,222,22,.22);
  border-radius:16px;
  padding:22px;
  height:100%;
  color:#fff;
  box-shadow:0 6px 24px rgba(13,75,38,.20);
}

.promo-tag{
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  color:var(--lime);
  letter-spacing:.6px;
}

.promo-cta{
  font-size:24px;
  font-weight:900;
  margin-top:10px;
  line-height:1.10;
}

/* ── PRODUTOS ─────────────────────────────────── */
.product-card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:16px;
  padding:12px;
  height:100%;
  transition:box-shadow .15s,transform .15s;
}
.product-card:hover{
  box-shadow:0 4px 18px rgba(26,107,58,.13);
  transform:translateY(-2px);
}

.product-img{
  border-radius:12px;
  height:92px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--bg-muted);
  border:1px dashed var(--border);
  color:var(--muted);
  font-size:26px;
  margin-bottom:10px;
}

.product-photo{
  border-radius:12px;
  height:92px;
  overflow:hidden;
  background:var(--bg-muted);
  border:1px solid var(--border);
  margin-bottom:10px;
}
.product-photo img{
  width:100%;height:100%;
  object-fit:contain;object-position:center;
  display:block;
}

.product-name{ font-size:13px; font-weight:800; margin-bottom:2px; color:var(--text); }
.product-meta{ font-size:12px; color:var(--muted); }
.product-price{ margin-top:8px; font-weight:900; color:var(--green); font-size:15px; }

/* ── SOBRE / PAINÉIS ──────────────────────────── */
.note{ color:var(--muted); font-size:12px; }

.panel{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:16px;
  padding:18px;
  box-shadow:0 2px 10px rgba(26,107,58,.07);
}

.panel-title{
  font-weight:900;
  font-size:16px;
  margin-bottom:8px;
  color:var(--green-dark);
}

.panel-text{ color:var(--text); font-size:14px; line-height:1.55; }

.features{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:8px;
  margin-top:12px;
}

.feature{
  background:var(--bg-muted);
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px;
  font-size:13px;
  display:flex;
  gap:8px;
  align-items:center;
  color:var(--text);
}
.feature i{ color:var(--green); }

/* ── MAPA ─────────────────────────────────────── */
.map{
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--border);
  background:var(--bg-muted);
  height:100%;
  min-height:320px;
  box-shadow:0 2px 10px rgba(26,107,58,.07);
}
.map iframe{ width:100%; height:100%; }

/* link de contato */
.link{ color:var(--green); font-weight:600; }
.link:hover{ color:var(--green-dark); }

/* btn WhatsApp no painel */
.btn-success{
  background:var(--green) !important;
  border-color:var(--green-dark) !important;
  font-weight:700;
}
.btn-success:hover{
  background:var(--green-dark) !important;
  border-color:var(--green-dark) !important;
}

/* ── FLOAT WHATSAPP ───────────────────────────── */
.whatsapp-float{
  position:fixed;
  right:18px;
  bottom:18px;
  width:56px;
  height:56px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#25D366;
  color:#fff;
  font-size:30px;
  box-shadow:0 8px 28px rgba(37,211,102,.40);
  transition:transform .15s,box-shadow .15s;
}
.whatsapp-float:hover{
  transform:scale(1.08);
  box-shadow:0 12px 36px rgba(37,211,102,.50);
}

/* ── FOOTER ───────────────────────────────────── */
.landing-footer{
  padding:24px 0;
  background:var(--green-dark);
  color:rgba(255,255,255,.80);
  font-size:14px;
}
.footer-small{ font-size:12px; color:rgba(255,255,255,.55); }

/* ── RESPONSIVE ───────────────────────────────── */
@media (max-width: 768px){
  .hero-card{ flex-direction:column; }
  .hero-title{ font-size:26px; }
  .brand-logo{ height:44px; }
  .hero-carousel img{ height:220px; }
  .hero-copy{ padding:20px; }
}
