/* ============================================================
   BUNDLE CSS — O Melhor da Madeira
   Gerado a partir de: global + header + home + home-banner +
   produtos + ajuda + filters + blog + clientes + hero + footer
   ============================================================ */

/* ==================== global.css ==================== */
:root {
  --font-primary: 'Roboto', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--font-primary);
  font-weight: 400;
  color: #2e2e2e;
}

:root {
  --verde-escuro: #0b4d1c;
  --verde-medio: #0f6b2a;
  --verde-claro: #e9f6ec;

  --cinza-texto: #555;
  --cinza-borda: #e5e5e5;

  --radius-lg: 20px;
  --radius-md: 14px;
}

@media (max-width: 980px) {
  .header-nav { padding: 18px; }
  .nav-list > li > a, .nav-btn { font-size: 1.05rem; padding: 18px; }
}

@media (max-width: 980px) {
  .nav-list > li > a, .nav-btn { font-size: 1.1rem; padding: 20px; }
}

@media (max-width: 768px) {
  html { font-size: 18px; }
  body { line-height: 1.6; }
}

.breadcrumb {
  max-width: 1320px;
  margin: 20px auto 10px;
  padding: 0 32px;
  font-size: 14px;
  color: #666;
}

.breadcrumb a { color: var(--verde-escuro); text-decoration: none; }
.breadcrumb span { margin: 0 6px; color: #aaa; }

.hero-global {
  background: #ffffff;
  border-bottom: 1px solid #eef2f1;
  padding: 56px 20px 48px;
}

.hero-container { max-width: 1200px; margin: 0 auto; text-align: center; }
.hero-breadcrumb { font-size: 14px; color: #6b7280; margin-bottom: 16px; }
.hero-breadcrumb a { color: #0b5d3b; text-decoration: none; font-weight: 500; }
.hero-breadcrumb span { margin: 0 6px; }

.hero-title { font-size: 40px; line-height: 1.2; font-weight: 700; color: #0f172a; margin-bottom: 12px; }
.hero-subtitle { max-width: 720px; margin: 0 auto; font-size: 17px; line-height: 1.6; color: #475569; }

@media (max-width: 768px) {
  .hero-title { font-size: 30px; }
  .hero-subtitle { font-size: 16px; }
}

#floating-cart {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 999;
  background: #0b5f2a;
  color: #ffffff;
  border-radius: 14px;
  box-shadow: 0 12px 30px rgba(0,0,0,0.18);
  padding: 14px 18px;
  min-width: 180px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-family: inherit;
  cursor: pointer;
  transition: transform .25s ease, box-shadow .25s ease, opacity .25s ease;
}

#floating-cart.hidden { opacity: 0; pointer-events: none; transform: translateY(20px); }
#floating-cart:hover { transform: translateY(-4px); box-shadow: 0 18px 38px rgba(0,0,0,0.25); }
#floating-cart .fc-content { display: flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 500; }
#floating-cart .fc-icon { font-size: 20px; }
#floating-cart .fc-count { line-height: 1.2; }
#floating-cart .fc-action { font-size: 13px; font-weight: 600; opacity: 0.9; display: flex; align-items: center; gap: 6px; }
#floating-cart .fc-action::after { content: "→"; transition: transform .2s ease; }
#floating-cart:hover .fc-action::after { transform: translateX(4px); }

@media (max-width: 640px) {
  #floating-cart { left: 16px; right: 16px; bottom: 16px; border-radius: 12px; min-width: auto; }
}

.home-section { padding: 100px 0; }

.container { width: 100%; max-width: 1300px; margin: 0 auto; padding: 0 40px; }

.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 40px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; }

@media (max-width: 768px) {
  .grid-4, .grid-3 { grid-template-columns: 1fr !important; gap: 24px !important; }
  .grid-4 > *, .grid-3 > * { width: 100% !important; max-width: 100% !important; }
  .container, .home-container { padding-left: 10px !important; padding-right: 10px !important; }
}

.filtros-wrapper { background: #f8f6f1; border-bottom: 1px solid #e8e4da; padding: 20px 0 16px; }
.filtros-bloco { display: flex; flex-direction: column; gap: 10px; }
.filtros-bloco + .filtros-bloco { margin-top: 14px; padding-top: 14px; border-top: 1px solid #e8e4da; }
.filtros-bloco-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.filtros-label { font-size: 13px; font-weight: 600; color: #3d3b35; display: flex; align-items: center; gap: 6px; }
.filtros-label-sm { font-weight: 500; color: #6b6860; }
.filtros-limpar { font-size: 12px; color: #888; text-decoration: none; transition: color .15s; }
.filtros-limpar:hover { color: #c0392b; }
.filtros-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.filtro-chip { display: inline-flex; align-items: center; padding: 7px 14px; border-radius: 20px; border: 1.5px solid #c8c4b8; background: #fff; color: #3d3b35; font-size: 13px; font-weight: 500; text-decoration: none; transition: border-color .15s, background .15s, color .15s; white-space: nowrap; }
.filtro-chip:hover { border-color: #0d4d1f; color: #0d4d1f; }
.filtro-chip.is-active { background: #0d4d1f; border-color: #0d4d1f; color: #fff; }
.filtros-chips-sm { gap: 6px; }
.filtro-chip-sm { padding: 5px 11px; font-size: 12px; border-width: 1px; border-color: #dddad2; color: #6b6860; }
.filtro-chip-sm:hover { border-color: #0d4d1f; color: #0d4d1f; }
.filtro-chip-sm.is-active { background: #e8f2ec; border-color: #0d4d1f; color: #0d4d1f; }

.wpp-float { position: fixed; bottom: 28px; right: 28px; z-index: 9999; display: flex; align-items: center; gap: 12px; background: #25d366; color: #fff; text-decoration: none; border-radius: 50px; padding: 12px 20px 12px 14px; box-shadow: 0 4px 18px rgba(0,0,0,0.22); transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.2s ease; max-width: 260px; }
.wpp-float:hover { background: #1ebe5d; transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,0.28); color: #fff; }
.wpp-float-icon { display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.2); border-radius: 50%; width: 40px; height: 40px; flex-shrink: 0; }
.wpp-float-icon i { font-size: 22px; line-height: 1; }
.wpp-float-text { display: flex; flex-direction: column; line-height: 1.3; }
.wpp-float-text strong { font-size: 13px; font-weight: 700; letter-spacing: 0.01em; }
.wpp-float-text span { font-size: 12px; opacity: 0.9; }
body.has-float-cart .wpp-float { bottom: 100px; }

@media (max-width: 640px) {
  .wpp-float { bottom: 16px; right: 16px; padding: 10px 16px 10px 12px; gap: 10px; }
  .wpp-float-icon { width: 34px; height: 34px; }
  .wpp-float-icon i { font-size: 19px; }
  .wpp-float-text strong { font-size: 12px; }
  .wpp-float-text span { font-size: 11px; }
}

.products-hero-sub { font-size: 15px; color: #666; margin-top: 6px; max-width: 560px; margin-inline: auto; }
.produtos-vazio { text-align: center; padding: 60px 20px; color: #888; }
.produtos-vazio p { margin-bottom: 16px; font-size: 16px; }

@media (max-width: 640px) {
  .filtros-chips { gap: 6px; }
  .filtro-chip { font-size: 12px; padding: 6px 12px; }
}

/* ==================== header.css ==================== */
.header-shop { background:#06461c; position:sticky; top:0; z-index:999; box-shadow:0 2px 12px rgba(0,0,0,.25); }
.header-shop .header-top { max-width:1280px; margin:0 auto; padding:14px 20px; display:flex; align-items:center; gap:18px; }
.header-logo { display:flex; align-items:center; flex-shrink:0; }
.header-logo img { height:48px; display:block; }
.header-search { display:flex; align-items:center; background:#fff; border-radius:999px; overflow:hidden; border:1px solid rgba(0,0,0,.08); height:44px; }
.header-search input { flex:1; border:0; outline:0; padding:0 18px; font-size:15px; height:100%; background:transparent; }
.header-search button { width:48px; height:100%; border:0; background:#0d6d2e; color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:16px; }
.header-search input::placeholder { color:#7a7a7a; opacity:1; }
.header-search button:hover { background:#0f7b33; }
.header-nav { flex:2; min-width:0; }
.header-nav .nav-list { display:flex; align-items:center; gap:14px; list-style:none; margin:0; padding:0; }
.header-nav .nav-list > li { flex:0 0 auto; }
.header-nav .nav-list a, .header-nav .nav-btn { color:#fff; background:none; border:0; cursor:pointer; text-decoration:none; font-size:14px; padding:9px 10px; border-radius:10px; display:flex; align-items:center; gap:8px; font-weight:500; white-space:nowrap; }
.header-nav .nav-list a:hover, .header-nav .nav-btn:hover { background:rgba(255,255,255,.08); }
.chevron { font-size:11px; opacity:.85; }
.nav-products-btn { background:#0d6d2e; border:1px solid rgba(255,255,255,.20); border-radius:12px; padding:9px 14px; font-weight:600; box-shadow:0 4px 10px rgba(0,0,0,.15); }
.nav-products-btn:hover { background:#0f7b33; }
.has-sub { position:relative; }
.sub-menu { position:absolute; top:100%; left:0; min-width:240px; background:#0f6a2f; border-radius:12px; padding:10px 0; display:none; z-index:2000; box-shadow:0 16px 40px rgba(0,0,0,.25); border:1px solid rgba(255,255,255,.08); }
.has-sub:hover > .sub-menu { display:block; }
.has-sub.open > .sub-menu { display:block; }
.sub-menu li { list-style:none; }
.sub-menu li a { display:block; padding:10px 16px; font-size:14px; color:#fff; text-decoration:none; }
.sub-menu li a:hover { background:rgba(255,255,255,.12); }
.header-actions { display:flex; align-items:center; gap:12px; flex-shrink:0; }
.account-link, .account-btn { display:flex; align-items:center; gap:8px; color:#fff; text-decoration:none; font-size:14px; padding:9px 12px; border-radius:12px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.10); transition:all .2s ease; }
.account-link:hover, .account-btn:hover { background:rgba(255,255,255,.12); }
.account-logged { position:relative; }
.account-dropdown { position:absolute; top:calc(100% + 8px); right:0; min-width:190px; background:#0f6a2f; border-radius:12px; padding:10px 0; display:none; z-index:1100; box-shadow:0 16px 40px rgba(0,0,0,.25); }
.account-logged.open .account-dropdown { display:block; }
.account-dropdown a { display:block; padding:10px 14px; color:#fff; text-decoration:none; font-size:14px; }
.account-dropdown a:hover { background:rgba(255,255,255,.10); }
.header-toggle { display:none; background:none; border:0; cursor:pointer; }
.header-toggle span { display:block; width:24px; height:3px; background:#fff; margin:5px 0; }
.mobile-only { display:none; }
.desktop-only { display:block; }
.mobile-search { display:none; padding:14px 16px; background:#06461c; border-top:1px solid rgba(255,255,255,.08); }
.mobile-search .header-search { border-radius:999px; }
.header-nav-mobile { display:none; background:#06461c; padding:16px 15px 15px; }
.nav-list-mobile { list-style:none; margin:0; padding:0; }
.nav-list-mobile li { margin-bottom:10px; }
.nav-list-mobile a { display:block; font-size:15px; font-weight:500; color:#fff; text-decoration:none; }
.nav-list-mobile .nav-btn { width:100%; display:flex; align-items:center; justify-content:space-between; font-size:15px; font-weight:500; color:#fff; border:0; background:none; cursor:pointer; padding:0; }
.nav-list-mobile .has-sub > .nav-btn::after { content:"▾"; font-size:16px; color:#9be49b; margin-left:10px; transition:transform .2s ease; }
.nav-list-mobile .has-sub.open > .nav-btn::after { transform:rotate(180deg); }
.header-nav-mobile .sub-menu { position:static !important; display:none; background:rgba(255,255,255,.08); border-radius:10px; padding:10px 10px; margin-top:10px; box-shadow:none; }
.header-nav-mobile .has-sub.open > .sub-menu { display:block; }
.header-nav-mobile .sub-menu a { font-size:15px; padding:5px 0; display:block; opacity:.9; }

@media (max-width:980px) {
  .desktop-only { display:none !important; }
  .mobile-only { display:block !important; }
  .header-shop .header-top { padding:12px 16px; gap:12px; }
  .header-logo img { height:46px; }
  .account-text { display:none; }
  .header-toggle { display:block; }
  .mobile-search { display:block; }
  .header-nav-mobile.open { display:block; animation:menuFade .25s ease; }
}

@keyframes menuFade { from { opacity:0; transform:translateY(-6px); } to { opacity:1; transform:translateY(0); } }

.header-nav, .header-nav .nav-list, .header-nav .nav-list > li, .has-sub { overflow:visible !important; }
.header-nav .nav-list { overflow:visible !important; }
.has-sub > .sub-menu { z-index:2000; }

/* ==================== home.css ==================== */
.home-section { padding: 30px 0; }
.home-section.alt-bg { background: #f8f9fa; }
.home-container { width: 100%; max-width: 1320px; margin: 0 auto; padding: 0 40px; }
.section-header { text-align: center; margin-bottom: 60px; }
.section-header h2 { font-size: 32px; font-weight: 700; color: #1c1c1c; margin-bottom: 15px; }
.section-header p { color: #666; font-size: 16px; }
.home-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.home-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.home-processo { background: linear-gradient(180deg, #f8f9fa 0%, #ffffff 100%); }
.processo-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 50px; margin-top: 60px; }
.processo-card { background: #ffffff; padding: 60px 40px; border-radius: 20px; box-shadow: 0 15px 45px rgba(0,0,0,0.06); text-align: center; transition: 0.3s ease; }
.processo-card:hover { transform: translateY(-8px); }
.processo-icon-circle { width: 80px; height: 80px; margin: 0 auto 25px; border-radius: 50%; background: #e6f2eb; display: flex; align-items: center; justify-content: center; }
.processo-icon-circle i { font-size: 28px; color: #0f4d2e; }
.processo-card h3 { font-size: 19px; font-weight: 700; margin-bottom: 15px; }
.processo-card p { font-size: 15px; color: #666; line-height: 1.6; }
.home-cta { background: #0f4d2e; color: #ffffff; text-align: center; padding: 30px 20px; }
.home-cta h2 { font-size: 28px; margin-bottom: 15px; }
.home-cta p { font-size: 16px; opacity: 0.85; }
.btn-cta { display: inline-block; margin-top: 30px; background: #ffffff; color: #0f4d2e; padding: 14px 40px; border-radius: 30px; font-weight: 600; transition: 0.3s ease; text-decoration: none; }
.btn-cta:hover { background: #e6e6e6; }

@media (max-width: 1200px) { .home-grid-4 { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 992px) { .home-grid-4, .home-grid-3, .processo-grid { grid-template-columns: repeat(2, 1fr); } .home-section { padding: 80px 0; } }
@media (max-width: 600px) { .home-grid-4, .home-grid-3, .processo-grid { grid-template-columns: 2fr; } .home-container { padding: 0 20px; } .section-header h2 { font-size: 24px; } .home-cta { padding: 70px 20px; } }

.home-institucional .card-pagina { background: #ffffff; border-radius: 18px; overflow: hidden; box-shadow: 0 12px 35px rgba(0,0,0,0.06); transition: 0.3s ease; }
.home-institucional .card-pagina:hover { transform: translateY(-6px); }
.home-institucional .card-blog-link { display: block; text-decoration: none; color: inherit; }
.home-institucional .card-blog-image { width: 100%; height: 220px; overflow: hidden; }
.home-institucional .card-blog-image img { width: 100%; height: 100%; object-fit: cover; transition: 0.4s ease; }
.home-institucional .card-pagina:hover img { transform: scale(1.05); }
.home-institucional .card-blog-content { padding: 30px; }
.home-institucional .card-blog-title { font-size: 18px; font-weight: 600; margin-bottom: 15px; color: #1c1c1c; }
.home-institucional .card-blog-excerpt { font-size: 14px; color: #666; margin-bottom: 20px; line-height: 1.5; }
.home-institucional .card-blog-readmore { font-size: 14px; font-weight: 600; color: #0f4d2e; }
.home-institucional .card-blog-media { width: 100%; aspect-ratio: 1 / 1; overflow: hidden; position: relative; }
.home-institucional .card-blog-media img, .home-institucional .card-blog-media picture { width: 100%; height: 100%; display: block; }
.home-institucional .card-blog-media img { object-fit: cover; transition: 0.4s ease; }
.home-institucional .card-pagina:hover .card-blog-media img { transform: scale(1.05); }

.home-atacado { background: linear-gradient(180deg, #f4f7f4 0%, #ffffff 100%); padding: 30px 0; }
.atacado-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; margin-top: 60px; }
.atacado-card { background: #ffffff; padding: 50px 35px; border-radius: 20px; text-align: center; box-shadow: 0 15px 45px rgba(0,0,0,0.05); transition: all .3s ease; position: relative; }
.atacado-card:hover { transform: translateY(-8px); box-shadow: 0 20px 55px rgba(0,0,0,0.08); }
.atacado-card.destaque { background: #0f4d2e; color: #fff; }
.atacado-card.destaque .atacado-tag { background: rgba(255,255,255,0.2); color: #fff; }
.atacado-icon { width: 80px; height: 80px; margin: 0 auto 25px; border-radius: 50%; background: #e6f2eb; display: flex; align-items: center; justify-content: center; }
.atacado-card.destaque .atacado-icon { background: rgba(255,255,255,0.15); }
.atacado-icon i { font-size: 28px; color: #0f4d2e; }
.atacado-card.destaque .atacado-icon i { color: #fff; }
.atacado-card h3 { font-size: 20px; font-weight: 700; margin-bottom: 15px; }
.atacado-card p { font-size: 15px; line-height: 1.6; margin-bottom: 20px; opacity: .9; }
.atacado-tag { display: inline-block; padding: 6px 14px; font-size: 12px; border-radius: 999px; background: #e6f2eb; color: #0f4d2e; font-weight: 600; }
.atacado-cta { text-align: center; margin-top: 60px; }
.btn-cta-atacado { background: #0f4d2e; color: #fff; padding: 16px 40px; border-radius: 40px; font-weight: 600; text-decoration: none; transition: .3s ease; }
.btn-cta-atacado:hover { background: #083a21; }

@media (max-width: 992px) { .atacado-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .atacado-grid { grid-template-columns: 1fr; } }

.section-subtitle { max-width: 720px; margin: 10px auto 0; font-size: 16px; line-height: 1.6; color: #5f6f65; }
@media (max-width: 768px) { .section-subtitle { font-size: 14px; padding: 0 12px; } }

@media (max-width: 768px) {
  .home-produtos .produtos-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 12px; }
  .home-produtos .produto-info { padding: 12px; }
  .home-produtos .produto-info h3 { font-size: 13px; line-height: 1.3; margin-bottom: 4px; }
  .home-produtos .produto-preco { margin: 6px 0 10px; }
  .home-produtos .preco-inline-row { display: flex; align-items: baseline; gap: 4px; flex-wrap: nowrap; }
  .home-produtos .preco-min { flex: unset; font-size: 20px; white-space: nowrap; }
  .home-produtos .preco-ate { font-size: 11px; white-space: nowrap; }
  .home-produtos .preco-max { font-size: 16px; white-space: nowrap; }
  .home-produtos .btn-ver { font-size: 13px; padding: 9px; }
}

/* ==================== home-banner.css ==================== */
.swiper { width: 100%; height: 100%; }
.swiper-wrapper { display: flex; }
.swiper-slide { flex-shrink: 0; }
.home-banner { position: relative; width: 100%; }
.banner-slide { height: 480px; position: relative; overflow: hidden; }
.banner-slide picture, .banner-slide img { width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; }
.banner-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.32); z-index: 1; pointer-events: none; }
.banner-link { display: block; width: 100%; height: 100%; position: relative; color: inherit; text-decoration: none; }
.banner-content { position: absolute; z-index: 2; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 100%; max-width: 780px; padding: 0 24px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.banner-content h2 { display: inline-block; background: #2f7d32; color: #fff; border-radius: 999px; padding: 16px 44px; font-size: 2.4rem; font-weight: 700; line-height: 1.15; margin: 0; box-shadow: 0 4px 18px rgba(0,0,0,0.25); }
.banner-subtitle { display: inline-block; background: rgba(255,255,255,0.92); color: #1a1a1a; border-radius: 999px; padding: 10px 30px; font-size: 1rem; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; margin: 0; box-shadow: 0 2px 10px rgba(0,0,0,0.15); }
.banner-price { display: inline-block; background: rgba(0,0,0,0.48); color: #fff; border-radius: 999px; padding: 7px 22px; font-size: 1rem; font-weight: 400; margin: 0; backdrop-filter: blur(2px); }
.banner-tag { display: inline-block; padding: 6px 16px; border-radius: 999px; font-size: 12px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: #fff; margin: 0; }
.banner-tag-promocao { background: #f97316; }
.banner-tag-inspiracoes { background: #15803d; }
.banner-tag-institucional { background: #7c4a1d; }
.banner-btn { display: inline-block; margin: 0; padding: 13px 36px; background: #2f7d32; color: #fff; border-radius: 8px; font-size: 1rem; font-weight: 600; letter-spacing: 0.02em; text-decoration: none; box-shadow: 0 4px 14px rgba(0,0,0,0.25); transition: background 0.25s, box-shadow 0.25s; }
.banner-btn:hover { background: #1b5e20; box-shadow: 0 6px 20px rgba(0,0,0,0.32); }

@media (max-width: 768px) {
  .banner-slide { height: 380px; }
  .banner-content { gap: 12px; padding: 0 18px; }
  .banner-content h2 { font-size: 1.5rem; padding: 13px 28px; border-radius: 999px; }
  .banner-subtitle { font-size: 0.78rem; padding: 8px 20px; letter-spacing: 0.04em; }
  .banner-price { font-size: 0.85rem; padding: 6px 16px; }
  .banner-btn { padding: 11px 26px; font-size: 0.9rem; }
  .banner-tag { font-size: 11px; padding: 5px 13px; }
}

@media (max-width: 420px) {
  .banner-slide { height: 320px; }
  .banner-content h2 { font-size: 1.2rem; padding: 11px 22px; }
  .banner-subtitle { font-size: 0.72rem; padding: 7px 16px; }
}

.home-banner .swiper-button-prev, .home-banner .swiper-button-next { color: #fff !important; text-shadow: 0 1px 4px rgba(0,0,0,0.4); }
.home-banner .swiper-button-prev:hover, .home-banner .swiper-button-next:hover { color: #c8e6c9 !important; }
.home-banner .swiper-pagination-bullet { background-color: rgba(255,255,255,0.55) !important; opacity: 1 !important; }
.home-banner .swiper-pagination-bullet-active { background-color: #fff !important; }

/* ==================== produtos.css ==================== */
.products-hero { text-align: center; padding: 10px 20px 18px; }
.products-hero h1 { font-size: 28px; margin-bottom: 14px; }
.products-badge { display: inline-block; background: var(--verde-claro); color: var(--verde-escuro); padding: 10px 18px; border-radius: 999px; font-size: 14px; }
.produtos-section { padding: 40px 20px 60px; }
.produtos-grid { max-width: 1200px; margin: 0 auto; display: grid; gap: 28px; }
.produtos-grid { display: grid; gap: 32px; }

@media (min-width: 1024px) { .produtos-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 28px; } }
@media (min-width: 769px) and (max-width: 1023px) { .produtos-grid { grid-template-columns: repeat(2, 1fr); } }

.produto-card { background: #fff; border-radius: 18px; overflow: hidden; box-shadow: 0 10px 30px rgba(0,0,0,.08); transition: transform .25s ease, box-shadow .25s ease; display: flex; flex-direction: column; }
.produto-card:hover { transform: translateY(-6px); box-shadow: 0 18px 45px rgba(0,0,0,.12); }
.produto-img { width: 100%; aspect-ratio: 1 / 1; overflow: hidden; background: #f4f4f4; }
.produto-img img { width: 100%; height: 100%; object-fit: contain; display: block; }
.produto-info { padding: 16px 18px 18px; }
.produto-info h3 { font-size: 18px; margin-bottom: 6px; line-height: 1.35; }
.produto-info .categoria { font-size: 14px; color: var(--cinza-texto); display: block; margin-bottom: 14px; }
.badge-atacado { display: inline-block; background: linear-gradient(135deg, #0b4d1c, #146b2d); color: #fff; font-size: 0.75rem; font-weight: 600; padding: 6px 14px; border-radius: 999px; margin-bottom: 12px; }
.produto-preco { margin: 10px 0 14px; }
.preco-label { display: block; font-size: 11px; font-weight: 500; color: #6b746d; margin-bottom: 3px; }
.preco-inline-row { display: flex; align-items: baseline; gap: 8px; flex-wrap: nowrap; }
.preco-min { font-size: 30px; font-weight: 700; color: #0b7d3a; line-height: 1; letter-spacing: -0.8px; white-space: nowrap; }
.preco-min .preco-currency { font-size: 18px; vertical-align: super; font-weight: 600; letter-spacing: 0; }
.preco-ate { font-size: 13px; color: #6b746d; font-weight: 500; white-space: nowrap; }
.preco-max { font-size: 22px; font-weight: 700; color: #c0392b; letter-spacing: -0.4px; line-height: 1; white-space: nowrap; }
.preco-max .preco-currency { font-size: 13px; vertical-align: super; font-weight: 600; letter-spacing: 0; }
.preco-tagline { display: block; font-size: 11px; color: #6b746d; font-style: italic; margin-top: 5px; }
.btn-ver { display: block; text-align: center; background: var(--verde-escuro); color: #fff; padding: 11px; border-radius: 999px; font-size: 13px; text-decoration: none; transition: background .2s ease, transform .2s ease; }
.btn-ver:hover { background: #083914; transform: translateY(-2px); }

@media (max-width: 768px) {
  .products-hero { padding: 24px 16px 18px; }
  .products-hero h1 { font-size: 1.8rem; }
  .products-badge { font-size: 0.95rem; padding: 12px 18px; }
  .produtos-section { padding: 24px 0 48px; }
  .produtos-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 12px; }
  .produto-card { border-radius: 16px; }
  .produto-info { padding: 12px; }
  .produto-info h3 { font-size: 13px; line-height: 1.3; margin-bottom: 4px; }
  .produto-info .categoria { font-size: 12px; margin-bottom: 8px; }
  .produto-preco { margin: 6px 0 10px; }
  .preco-inline-row { gap: 4px; }
  .preco-min { font-size: 20px; letter-spacing: -0.5px; }
  .preco-min .preco-currency { font-size: 13px; }
  .preco-ate { font-size: 11px; }
  .preco-max { font-size: 16px; letter-spacing: -0.3px; }
  .preco-max .preco-currency { font-size: 10px; }
  .preco-tagline { font-size: 10px; margin-top: 3px; }
  .btn-ver { font-size: 13px; padding: 9px; }
}

.products-filtros-wrapper { margin: 40px 0; }
.filtros-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.filtro-card { background: #ffffff; border-radius: 20px; padding: 22px 20px 18px; border: 1px solid #e7efe9; box-shadow: none; }
.filtro-card-head { margin-bottom: 16px; }
.filtro-card h3 { display: flex; align-items: center; gap: 12px; margin-bottom: 4px; font-size: 20px; font-weight: 800; color: #0d4d1f; }
.filtro-card h3 i { width: 40px; height: 40px; border-radius: 14px; display: inline-flex; align-items: center; justify-content: center; background: #eaf3ed; color: #0d4d1f; font-size: 15px; box-shadow: none; }
.filtro-head-line { display: block; width: 38px; height: 2px; border-radius: 999px; background: #0d7a34; margin: 0 0 8px 52px; }
.filtro-card-head p { margin: 0; font-size: 14px; line-height: 1.45; color: #6b746d; margin-left: 52px; }
.filtro-botoes { display: flex; flex-wrap: wrap; gap: 8px; }
.filtro-btn { display: inline-flex; align-items: center; gap: 7px; padding: 9px 12px; font-size: 13px; border-radius: 999px; border: 1px solid #b9d0be; color: #0d4d1f; text-decoration: none; font-weight: 700; transition: 0.2s ease; background: #fdfefd; box-shadow: none; }
.filtro-btn i { font-size: 11px; opacity: 0.8; }
.filtro-btn:hover, .filtro-btn.active { background: #0d4d1f; color: #ffffff; border-color: #0d4d1f; transform: none; box-shadow: none; }

@media (max-width: 768px) {
  .filtros-grid { grid-template-columns: 1fr; gap: 16px; }
  .filtro-card { padding: 18px 16px 14px; border-radius: 18px; }
  .filtro-card h3 { font-size: 18px; }
  .filtro-card h3 i { width: 34px; height: 34px; border-radius: 12px; font-size: 13px; }
  .filtro-head-line, .filtro-card-head p { margin-left: 46px; }
  .filtro-head-line { width: 30px; margin-bottom: 6px; }
  .filtro-card-head p { font-size: 13px; }
  .filtro-botoes { gap: 7px; }
  .filtro-btn { width: 100%; justify-content: flex-start; padding: 10px 12px; font-size: 13px; }
}

/* ==================== ajuda.css ==================== */
.page-ajuda { padding-bottom: 40px; }
.ajuda-hero { background: linear-gradient(180deg, rgba(6,70,28,.08), rgba(6,70,28,0)); padding: 28px 0 10px; }
.ajuda-hero-grid { display:grid; grid-template-columns: 1.2fr .8fr; gap: 18px; align-items: stretch; }
.ajuda-hero-text h1 { margin:0; font-size: 34px; }
.ajuda-hero-text p { margin:10px 0 0; opacity:.85; }
.ajuda-hero-ctas { display:flex; gap:10px; margin-top: 14px; flex-wrap:wrap; }
.ajuda-microcopy { margin-top: 10px; font-size: 13px; opacity:.75; }
.ajuda-hero-card { border-radius: 18px; background: #fff; box-shadow: 0 10px 30px rgba(0,0,0,.06); padding: 16px; }
.ajuda-selos { display:grid; gap:10px; }
.selo { border:1px solid rgba(6,70,28,.15); background: rgba(6,70,28,.05); padding:10px 12px; border-radius: 14px; font-weight: 600; }
.ajuda-section { padding: 26px 0; }
.ajuda-section-alt { background: rgba(0,0,0,.02); border-top:1px solid rgba(0,0,0,.04); border-bottom:1px solid rgba(0,0,0,.04); }
.ajuda-cards { display:grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 14px; }
.ajuda-card { display:flex; align-items:center; gap: 10px; padding: 14px; border-radius: 16px; background:#fff; border:1px solid rgba(0,0,0,.06); box-shadow: 0 10px 25px rgba(0,0,0,.04); text-decoration:none; color: inherit; transition: transform .12s ease, box-shadow .12s ease; }
.ajuda-card:hover { transform: translateY(-2px); box-shadow: 0 14px 30px rgba(0,0,0,.08); }
.ajuda-card-ico { font-size: 22px; width: 36px; height: 36px; display:grid; place-items:center; border-radius: 12px; background: rgba(6,70,28,.06); }
.ajuda-card-body strong { display:block; }
.ajuda-card-body span { display:block; opacity:.8; font-size: 13px; margin-top: 2px; }
.ajuda-card-arrow { margin-left:auto; opacity:.5; font-size: 22px; }
.ajuda-card-static { cursor: default; }
.ajuda-card-static:hover { transform:none; box-shadow: 0 10px 25px rgba(0,0,0,.04); }
.ajuda-form { background:#fff; border:1px solid rgba(0,0,0,.06); border-radius: 18px; padding: 16px; box-shadow: 0 10px 25px rgba(0,0,0,.04); margin-top: 14px; }
.ajuda-form-grid { display:grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.field label { display:block; font-weight: 700; font-size: 13px; margin-bottom: 6px; }
.field input, .field textarea { width:100%; border:1px solid rgba(0,0,0,.12); border-radius: 12px; padding: 12px 12px; outline: none; }
.field input:focus, .field textarea:focus { border-color: rgba(6,70,28,.55); box-shadow: 0 0 0 3px rgba(6,70,28,.12); }
.field-full { grid-column: 1 / -1; }
.ajuda-form-actions { display:flex; gap:10px; flex-wrap:wrap; margin-top: 12px; }
.hp-wrap { position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.faq { display:grid; gap: 10px; margin-top: 14px; }
.faq-item { background:#fff; border:1px solid rgba(0,0,0,.06); border-radius: 16px; box-shadow: 0 10px 25px rgba(0,0,0,.04); overflow:hidden; }
.faq-q { width:100%; display:flex; align-items:center; justify-content:space-between; gap: 10px; padding: 14px 14px; background: transparent; border:0; cursor:pointer; text-align:left; font-weight: 800; }
.faq-q i { width:26px; height:26px; display:grid; place-items:center; border-radius: 10px; background: rgba(6,70,28,.06); }
.faq-a { padding: 0 14px 14px; }
.faq-a p { margin:0; opacity:.88; }
.ajuda-cta-final { padding: 18px 0 36px; }
.ajuda-cta-box { background: #06461c; color:#fff; border-radius: 18px; padding: 18px; box-shadow: 0 14px 35px rgba(0,0,0,.18); display:flex; align-items:center; justify-content:space-between; gap: 14px; flex-wrap:wrap; }
.ajuda-cta-box h3 { margin:0; font-size: 20px; }
.ajuda-cta-box p { margin:6px 0 0; opacity:.9; max-width: 560px; }
.whats-float { position: fixed; right: 16px; bottom: 16px; width: 54px; height: 54px; border-radius: 18px; background: #25D366; display:grid; place-items:center; color:#fff; text-decoration:none; font-size: 22px; box-shadow: 0 12px 30px rgba(0,0,0,.22); z-index: 999; }

@media (max-width: 980px) { .ajuda-hero-grid { grid-template-columns: 1fr; } .ajuda-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .ajuda-cards { grid-template-columns: 1fr; } .ajuda-form-grid { grid-template-columns: 1fr; } .ajuda-hero-text h1 { font-size: 28px; } }

.ajuda-seo { border-top:1px solid rgba(0,0,0,.05); background: rgba(6,70,28,.03); }
.ajuda-seo-content { max-width: 900px; margin: 0 auto; line-height: 1.7; font-size: 15px; }
.ajuda-seo-content p { margin-bottom: 14px; }

/* ==================== filters.css ==================== */
.products-filters { display: flex; justify-content: space-between; align-items: center; gap: 20px; margin: 30px 0; flex-wrap: wrap; padding-left: 32px; padding-right: 32px; }
.filters-left, .filters-right { display: flex; align-items: center; gap: 12px; }
.filters-label { font-weight: 600; font-size: 14px; color: #2e2e2e; }
.filters-categories { display: flex; gap: 8px; flex-wrap: wrap; }
.filter-btn { padding: 10px 18px; border-radius: 999px; background: var(--verde-escuro); color: #fff; font-size: 14px; text-decoration: none; transition: all .2s ease; }
.filter-btn:hover, .filter-btn.active { background: var(--verde-medio); }
.filters-search { display: flex; gap: 8px; }
.filters-search input { padding: 10px 16px; border-radius: 999px; border: 1px solid var(--cinza-borda); font-size: 14px; width: 220px; }
.filters-search button { background: var(--verde-escuro); color: #fff; border-radius: 999px; padding: 10px 18px; font-size: 14px; cursor: pointer; }

@media (max-width: 768px) {
  .products-filters { flex-direction: column; align-items: stretch; }
  .filter-select, .filters-search input { width: 100%; font-size: 15px; padding: 12px; }
  .filter-btn { font-size: 1rem; padding: 12px 20px; }
  .filter-select { font-size: 1.05rem; padding: 14px 16px; }
  .filters-search input { font-size: 1.05rem; padding: 14px 16px; }
  .filters-search button { font-size: 1.05rem; padding: 14px 20px; }
  .products-filters { gap: 24px; margin-top: 24px; }
  .filters-left, .filters-right { width: 100%; }
  .filters-categories.mobile-only { width: 100%; }
  .filter-select { width: 100%; font-size: 1.15rem; padding: 18px 16px; border-radius: 14px; }
  .filters-search { width: 100%; }
  .filters-search input { width: 100%; font-size: 1.1rem; padding: 18px 16px; border-radius: 14px; }
  .filters-search button { font-size: 1.1rem; padding: 18px 22px; border-radius: 14px; }
}

/* ==================== blog.css ==================== */
.blog-section { padding: 60px 20px; background: #f8faf8; }
.blog-grid { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.blog-card { background: #fff; border-radius: 12px; overflow: hidden; box-shadow: 0 8px 24px rgba(15,23,42,0.06); transition: transform .25s ease, box-shadow .25s ease; }
.blog-card:hover { transform: translateY(-4px); box-shadow: 0 14px 36px rgba(15,23,42,0.10); }
.blog-card-image { display: block; aspect-ratio: 16 / 9; overflow: hidden; background: #eef2ee; }
.blog-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.blog-card:hover img { transform: scale(1.04); }
.blog-card-content { padding: 20px 22px 26px; }
.blog-date { font-size: 13px; color: #6b7b6f; display: block; margin-bottom: 8px; }
.post-date { display: block; font-size: 14px; color: #6b7b6f; font-weight: 400; margin-top: 16px; }
.blog-card-link { display: inline-block; margin-top: 14px; font-size: 14px; font-weight: 600; color: #0b4d1c; text-decoration: underline; text-underline-offset: 3px; }
.blog-card-content h2 { font-size: 20px; line-height: 1.3; margin-bottom: 10px; }
.blog-card-content h2 a { color: #0f172a; text-decoration: none; }
.blog-card-content p { font-size: 15px; color: #475569; line-height: 1.6; }

@media (max-width: 1024px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .blog-grid { grid-template-columns: 1fr; } }

.blog-post { background: #fff; }
.blog-post-hero { max-width: 1200px; margin: 0 auto; padding: 40px 20px; }
.blog-post-hero-image img { width: 100%; height: auto; border-radius: 14px; margin-bottom: 24px; }
.blog-post-hero-content { max-width: 1200px; }
.blog-post-date { font-size: 14px; color: #6b7280; display: block; margin-bottom: 8px; }
.blog-post-hero h1 { font-size: 40px; line-height: 1.2; margin-bottom: 16px; }
.blog-post-subtitle { font-size: 18px; color: #475569; }
.blog-post-container { max-width: 1200px; margin: 0 auto; padding: 0 20px 80px; }
.blog-post-content { max-width: 1200px; font-size: 17px; line-height: 1.8; color: #1f2937; }
.blog-post-content p { margin-bottom: 1.4em; }
.blog-post-content img { max-width: 100%; border-radius: 10px; margin: 24px 0; }
.blog-post-gallery { margin-top: 64px; }
.blog-post-gallery h2 { margin-bottom: 24px; }
.blog-gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.blog-gallery-grid img { width: 100%; border-radius: 10px; }
.blog-related { margin-top: 60px; margin-bottom: 40px; }
.blog-related-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 24px; }
.blog-related-card { display: flex; gap: 16px; background: #f8fafc; border-radius: 14px; padding: 14px; align-items: center; transition: transform .2s ease, box-shadow .2s ease; }
.blog-related-card:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(0,0,0,.08); }
.blog-related-thumb { flex-shrink: 0; width: 120px; height: 90px; overflow: hidden; border-radius: 10px; }
.blog-related-thumb img { width: 100%; height: 100%; object-fit: cover; }
.blog-related-content { display: flex; flex-direction: column; }
.blog-related-content h3 { font-size: 16px; line-height: 1.4; margin: 4px 0 0; }
.blog-related-content h3 a { color: #0f172a; text-decoration: none; }
.blog-related-content h3 a:hover { text-decoration: underline; }

@media (max-width: 768px) { .blog-post-hero h1 { font-size: 28px; } }

.blog-post-cover { max-height: 300px; overflow: hidden; border-radius: 16px; margin: 40px auto; }
.blog-post-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.blog-gallery { background: #f4f7f4; padding: 60px 60px; margin-top: 40px; }
.blog-gallery-title { font-size: 28px; margin-bottom: 32px; color: #0b4d1c; }
.blog-gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; }
.blog-gallery-item img { width: 100%; height: 220px; object-fit: cover; border-radius: 14px; transition: transform .3s ease; }
.blog-gallery-item:hover img { transform: scale(1.04); }
.post-cover { max-width: 1200px; margin: 0 auto; height: 300px; overflow: hidden; border-radius: 16px; }
.post-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ==================== clientes.css ==================== */
.cliente-cadastro { padding: 60px 20px; }
.form-box { max-width: 720px; margin: auto; background: #fff; padding: 40px; border-radius: 18px; box-shadow: 0 10px 30px rgba(0,0,0,.06); }
.form-grid { display: grid; gap: 16px; margin-top: 25px; }
.form-grid input { padding: 14px; border-radius: 10px; border: 1px solid #ddd; font-size: 15px; }
.btn-primary { margin-top: 25px; background: #06461c; color: #fff; padding: 14px; border: none; border-radius: 12px; font-weight: 600; cursor: pointer; }
.cliente-painel { padding: 60px 20px; background: #f6f8f7; min-height: 70vh; }
.painel-container { max-width: 1100px; margin: 0 auto; }
.painel-header { margin-bottom: 40px; }
.painel-header h1 { font-size: 32px; margin-bottom: 8px; }
.painel-header p { color: #666; }
.painel-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.painel-card { background: #ffffff; border-radius: 14px; padding: 30px; box-shadow: 0 8px 25px rgba(0,0,0,0.05); transition: 0.3s ease; }
.painel-card:hover { transform: translateY(-3px); }
.painel-card h3 { margin-bottom: 20px; font-size: 18px; border-bottom: 1px solid #eee; padding-bottom: 10px; }
.painel-info p { margin-bottom: 12px; font-size: 14px; }
.painel-actions { margin-top: 25px; }
.btn-outline { display: inline-block; padding: 10px 18px; border: 2px solid #0b4d2b; color: #0b4d2b; border-radius: 8px; text-decoration: none; font-weight: 500; transition: 0.3s ease; }
.btn-outline:hover { background: #0b4d2b; color: #fff; }
.painel-empty { padding: 20px; background: #f2f4f3; border-radius: 8px; font-size: 14px; color: #666; }

@media (max-width: 900px) { .painel-grid { grid-template-columns: 1fr; } }

.painel-pedidos { display: flex; flex-direction: column; gap: 15px; }
.pedido-item { padding: 15px; background: #f7f9f8; border-radius: 10px; transition: 0.3s ease; }
.pedido-item:hover { background: #eef3f1; }
.pedido-info { display: flex; justify-content: space-between; font-size: 14px; margin-bottom: 5px; }
.pedido-meta { display: flex; justify-content: space-between; align-items: center; }
.status { padding: 4px 10px; border-radius: 20px; font-size: 11px; font-weight: bold; }
.status.novo { background: #e3f2fd; color: #1976d2; }
.status.aprovado { background: #e8f5e9; color: #2e7d32; }
.status.cancelado { background: #ffebee; color: #c62828; }
.cliente-container { max-width: 1100px; margin: 60px auto; padding: 0 20px; }
.pedido-card { background: #fff; border-radius: 18px; padding: 30px; box-shadow: 0 10px 25px rgba(0,0,0,.06); }
.pedido-header { display: flex; justify-content: space-between; margin-bottom: 20px; }
.pedido-status { background: #e6f3ff; color: #007bff; padding: 6px 14px; border-radius: 20px; font-weight: 600; font-size: 14px; }
.pedido-itens table { width: 100%; border-collapse: collapse; }
.pedido-itens th, .pedido-itens td { padding: 10px; border-bottom: 1px solid #eee; }
.pedido-total { text-align: right; margin-top: 20px; font-size: 18px; }
.painel-pedidos { display: flex; flex-direction: column; gap: 16px; }
.pedido-card-link { text-decoration: none; color: inherit; }
.pedido-item { background: #fff; border-radius: 16px; padding: 20px 24px; display: flex; justify-content: space-between; align-items: center; box-shadow: 0 8px 20px rgba(0,0,0,.05); transition: .25s ease; }
.pedido-item:hover { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(0,0,0,.08); }
.pedido-left { display: flex; flex-direction: column; gap: 6px; }
.pedido-id { font-weight: 600; font-size: 16px; }
.pedido-data { font-size: 13px; color: #777; }
.pedido-right { text-align: right; }
.pedido-total { font-size: 18px; font-weight: 700; margin-bottom: 6px; }
.status { padding: 4px 12px; border-radius: 20px; font-size: 12px; font-weight: 600; }
.status-novo { background: #e6f3ff; color: #007bff; }
.status-negociando { background: #fff3cd; color: #856404; }
.status-fechado { background: #d4edda; color: #155724; }
.status-cancelado { background: #f8d7da; color: #721c24; }
.status-aprovado, .status-green { background: #d4edda; color: #155724; }
.status-em_producao, .status-slate { background: #e0e7ff; color: #3730a3; }
.status-expedido, .status-purple { background: #f3e8ff; color: #7c3aed; }
.status-entregue, .status-emerald { background: #dcfce7; color: #166534; }
.status-blue { background: #e6f3ff; color: #007bff; }
.status-orange { background: #fff3cd; color: #856404; }
.status-red { background: #f8d7da; color: #721c24; }
.pedido-historico { margin-top: 28px; }
.pedido-historico-lista { display: flex; flex-direction: column; gap: 12px; margin-top: 14px; }
.pedido-historico-item { border: 1px solid #e5e7eb; border-radius: 12px; padding: 14px 16px; background: #fafafa; }
.pedido-historico-topo { display: flex; justify-content: space-between; gap: 12px; margin-bottom: 6px; }
.pedido-historico-topo span { color: #6b7280; font-size: 13px; }
.pedido-historico-meta, .pedido-historico-obs { color: #4b5563; font-size: 14px; }
.pedido-vazio { background: #f3f3f3; padding: 25px; border-radius: 14px; text-align: center; color: #777; }
.login-wrapper { min-height: 80vh; display: flex; justify-content: center; align-items: center; padding: 40px 20px; }
.login-card { background: #fff; width: 100%; max-width: 420px; padding: 40px 35px; border-radius: 20px; box-shadow: 0 15px 40px rgba(0,0,0,.08); }
.login-card h1 { margin-bottom: 10px; font-size: 28px; }
.login-subtitle { font-size: 14px; color: #777; margin-bottom: 25px; }
.login-form { display: flex; flex-direction: column; gap: 18px; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group label { font-size: 13px; font-weight: 600; color: #333; }
.form-group input { padding: 12px 14px; border-radius: 10px; border: 1px solid #ddd; font-size: 14px; transition: .2s; }
.form-group input:focus { border-color: #0d5c2f; outline: none; box-shadow: 0 0 0 3px rgba(13,92,47,.1); }
.btn-login { background: #0d5c2f; color: #fff; border: none; padding: 14px; border-radius: 12px; font-weight: 600; font-size: 15px; cursor: pointer; transition: .25s; }
.btn-login:hover { background: #0a4724; transform: translateY(-2px); }
.login-footer { margin-top: 20px; text-align: center; font-size: 14px; }
.login-footer a { color: #0d5c2f; font-weight: 600; text-decoration: none; }
.login-footer a:hover { text-decoration: underline; }
.login-erro { background: #f8d7da; color: #721c24; padding: 12px; border-radius: 10px; margin-bottom: 20px; font-size: 13px; }
.dados-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; }
.btn-editar { background: #0f5c2a; color: #fff; padding: 6px 14px; border-radius: 20px; font-size: 13px; text-decoration: none; }
.link-senha { display: inline-block; margin-top: 15px; font-size: 13px; color: #0f5c2a; }
.pedido-card h2 i { margin-right: 8px; color: #0d5c2f; }
.pedido-header h2 { font-size: 22px; }
.pedido-itens thead { background: #f4f6f5; }
.pedido-itens th { text-align: left; font-size: 13px; text-transform: uppercase; color: #666; }
.pedido-total { font-size: 20px; font-weight: 700; color: #0d5c2f; }
.btn-voltar { display: inline-flex; align-items: center; gap: 8px; padding: 10px 18px; border-radius: 30px; background: #f2f4f3; color: #0d5c2f; text-decoration: none; font-weight: 600; font-size: 14px; transition: all .25s ease; }
.btn-voltar i { font-size: 13px; }
.btn-voltar:hover { background: #0d5c2f; color: #fff; transform: translateX(-2px); }
.painel-kicker { display: inline-flex; padding: 6px 12px; border-radius: 999px; background: #e7efe8; color: #0d5c2f; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 14px; }
.cliente-alert { margin: 0 0 22px; padding: 14px 16px; border-radius: 14px; font-size: 14px; }
.cliente-alert-success { background: #eaf8ee; color: #166534; border: 1px solid #bbf7d0; }
.painel-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 20px; }
.painel-overview { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-bottom: 28px; }
.overview-card { background: linear-gradient(135deg, #103b20 0%, #215f38 100%); color: #fff; border-radius: 20px; padding: 24px; box-shadow: 0 18px 40px rgba(16,59,32,.18); }
.overview-card strong { display: block; font-size: 34px; margin: 10px 0 8px; }
.overview-card p, .overview-label { color: rgba(255,255,255,.8); }
.overview-label { font-size: 12px; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; }
.painel-card-highlight { background: linear-gradient(180deg, #ffffff 0%, #f5faf7 100%); }
.pedido-highlight { display: flex; flex-direction: column; gap: 18px; }
.pedido-highlight-top { display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; }
.pedido-highlight-id { font-size: 22px; font-weight: 700; color: #12331d; }
.pedido-highlight-date, .pedido-link-hint, .pedido-progress small, .painel-lista-header p, .pedido-subtitle, .tracking-step span, .pedido-frete-grid span { color: #6b7280; }
.pedido-progress { display: flex; flex-direction: column; gap: 8px; }
.pedido-progress-bar { height: 10px; border-radius: 999px; background: #e5e7eb; overflow: hidden; }
.pedido-progress-bar span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, #1d7c46 0%, #4caf72 100%); }
.pedido-highlight-total { color: #12331d; font-size: 15px; }
.painel-lista { margin-top: 28px; }
.painel-lista-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; }
.pedido-header-status { display: flex; align-items: flex-start; }
.pedido-subtitle { margin-top: 8px; }
.pedido-resumo-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; margin: 24px 0 28px; }
.pedido-resumo-card, .pedido-frete-box { background: #f8faf9; border: 1px solid #e5ebe7; border-radius: 16px; padding: 18px; }
.pedido-resumo-card span, .pedido-frete-grid span { display: block; font-size: 13px; margin-bottom: 8px; }
.pedido-resumo-card strong, .pedido-frete-grid strong { color: #12331d; font-size: 18px; }
.pedido-tracking { margin: 12px 0 28px; padding: 22px; border-radius: 18px; background: #fcfdfc; border: 1px solid #e5ebe7; }
.pedido-tracking-header { display: flex; justify-content: space-between; gap: 18px; align-items: center; margin-bottom: 16px; }
.pedido-tracking-header h3, .pedido-frete-box h3, .painel-lista-header h3 { margin-bottom: 6px; }
.pedido-progress-detail { margin-bottom: 18px; }
.tracking-steps { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 12px; }
.tracking-step { border: 1px solid #e5e7eb; border-radius: 14px; padding: 14px 12px; background: #fff; min-height: 110px; display: flex; flex-direction: column; gap: 8px; }
.tracking-step strong { color: #111827; font-size: 14px; }
.tracking-step-current { border-color: #8ed0a7; box-shadow: 0 10px 25px rgba(29,124,70,.10); }
.tracking-step-completed { background: #f3fbf6; }
.tracking-step-dot { width: 14px; height: 14px; border-radius: 50%; }
.tracking-step-dot-blue { background: #007bff; }
.tracking-step-dot-orange { background: #f59e0b; }
.tracking-step-dot-green { background: #16a34a; }
.tracking-step-dot-slate { background: #475569; }
.tracking-step-dot-purple { background: #7c3aed; }
.tracking-step-dot-emerald { background: #059669; }
.pedido-tracking-alert { margin: 0 0 16px; padding: 14px 16px; border-radius: 12px; background: #fff3f2; color: #991b1b; border: 1px solid #fecaca; }
.pedido-frete-box { margin-bottom: 28px; }
.pedido-frete-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.pedido-acoes { margin-top: 22px; display: flex; justify-content: flex-end; }

@media (max-width: 900px) {
  .painel-header, .pedido-header, .pedido-tracking-header, .pedido-highlight-top { flex-direction: column; align-items: flex-start; }
  .painel-overview, .pedido-resumo-grid, .pedido-frete-grid, .tracking-steps { grid-template-columns: 1fr; }
  .pedido-item { flex-direction: column; align-items: flex-start; gap: 16px; }
  .pedido-right, .pedido-acoes { text-align: left; justify-content: flex-start; }
}

.cliente-completar { padding:60px 20px; background:#f6f7f8; }
.completar-card { max-width:650px; margin:auto; background:#fff; padding:40px; border-radius:10px; box-shadow:0 10px 25px rgba(0,0,0,0.08); }
.completar-card h1 { margin-bottom:10px; }
.completar-info { color:#666; margin-bottom:30px; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:30px; }
.form-field { display:flex; flex-direction:column; }
.form-field label { font-size:14px; margin-bottom:6px; }
.form-field input, .form-field select { padding:10px; border:1px solid #ddd; border-radius:6px; }
.btn-primary { background:#0b5e2b; color:#fff; border:none; padding:14px 22px; border-radius:6px; cursor:pointer; font-weight:bold; }
.btn-primary:hover { background:#094c22; }

/* ==================== hero.css ==================== */
.page-hero { background: #ffffff; border-bottom: 1px solid #eef2ee; padding: 60px 20px 40px; }
.page-hero-inner { max-width: 1200px; margin: 0 auto; }
.page-hero h1 { font-size: 36px; line-height: 1.2; color: #0f172a; margin-bottom: 12px; }
.page-hero .hero-subtitle { margin-left: 0; margin-right: 0; }
@media (max-width: 768px) { .page-hero h1 { font-size: 28px; } }

/* ==================== footer.css ==================== */
.footer-commercial { background: #0f3d2e; color: #e6f2ed; font-size: 15px; line-height: 1.6; }
.footer-cta { background: linear-gradient(135deg, #1f7a5a, #145c43); padding: 60px 20px; }
.footer-cta-split { display: flex; align-items: center; gap: 0; }
.footer-cta-part { flex: 1; padding: 0 40px; }
.footer-cta-main { text-align: center; }
.footer-cta-divider { width: 1px; min-height: 160px; background: rgba(255,255,255,0.2); flex-shrink: 0; align-self: stretch; }
.footer-cta h2 { font-size: 28px; margin-bottom: 10px; color: #ffffff; }
.footer-cta p { max-width: 720px; margin: 0 auto 25px; font-size: 16px; color: #dff5ed; }
.footer-cta-actions { display: flex; justify-content: center; gap: 15px; flex-wrap: wrap; }
.footer-featured-card { display: flex; align-items: center; gap: 18px; text-decoration: none; background: rgba(0,0,0,0.18); border-radius: 10px; padding: 20px; transition: background 0.25s ease; }
.footer-featured-card:hover { background: rgba(0,0,0,0.30); }
.footer-featured-thumb { width: 120px; height: 90px; object-fit: cover; border-radius: 6px; flex-shrink: 0; }
.footer-featured-label { display: block; font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #25d366; margin-bottom: 6px; }
.footer-featured-body h3 { font-size: 16px; color: #ffffff; margin: 0 0 8px; line-height: 1.4; }
.footer-featured-body p { font-size: 13px; color: #dff5ed; margin: 0 0 14px; line-height: 1.5; }
.btn-sm { padding: 8px 16px; font-size: 13px; }
.btn { display: inline-flex; align-items: center; gap: 8px; padding: 14px 26px; border-radius: 6px; font-weight: 600; text-decoration: none; transition: all 0.25s ease; }
.btn i { font-size: 16px; }
.btn-whatsapp { background-color: #25d366; color: #083c2a; }
.btn-whatsapp:hover { background-color: #1ebe5d; transform: translateY(-2px); }
.btn-outline { border: 2px solid #ffffff; color: #ffffff; }
.btn-outline:hover { background: #ffffff; color: #0f3d2e; }
.btn-block { display: flex; justify-content: center; margin-top: 15px; }
.footer-main { padding: 60px 20px; }
.footer-grid-3, .footer-grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 50px; }
.footer-state-list { columns: 2; column-gap: 20px; }
.footer-state-list li { break-inside: avoid; }
.footer-column h4 { font-size: 17px; margin-bottom: 18px; color: #ffffff; position: relative; }
.footer-column h4::after { content: ""; width: 40px; height: 3px; background-color: #25d366; display: block; margin-top: 8px; }
.footer-column ul { list-style: none; padding: 0; margin: 0; }
.footer-column ul li { margin-bottom: 10px; }
.footer-column ul li a { color: #cfe8df; text-decoration: none; transition: color 0.2s ease; }
.footer-column ul li a:hover { color: #25d366; }
.footer-seo-text { font-size: 14px; margin-bottom: 18px; color: #c9e6da; }
.footer-seo-text strong { color: #ffffff; }
.footer-contact p { margin-bottom: 12px; }
.footer-contact a { color: #ffffff; text-decoration: none; font-weight: 600; }
.footer-contact a:hover { color: #25d366; }
.footer-security { background: #0c3326; padding: 30px 20px; }
.footer-security-grid { display: flex; justify-content: space-between; gap: 30px; flex-wrap: wrap; }
.security-item { display: flex; gap: 15px; align-items: flex-start; flex: 1; min-width: 250px; }
.security-item i { font-size: 20px; color: #25d366; margin-top: 4px; }
.security-item strong { display: block; color: #ffffff; }
.security-item p { margin: 5px 0 0; font-size: 14px; color: #cfe8df; }
.footer-bottom { background: #09261c; padding: 25px 20px; font-size: 13px; }
.footer-bottom-grid { display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; }
.footer-bottom p { margin: 0; color: #a7d7c4; }
.footer-legal a { color: #a7d7c4; margin-left: 15px; text-decoration: none; font-size: 13px; }
.footer-legal a:hover { color: #25d366; }

@media (max-width: 992px) {
  .footer-grid-3, .footer-grid-4 { grid-template-columns: 1fr 1fr; gap: 40px; }
  .footer-state-list { columns: 1; }
}

@media (max-width: 768px) {
  .footer-cta-split { flex-direction: column; gap: 30px; }
  .footer-cta-part { padding: 0; width: 100%; }
  .footer-cta-divider { width: 60%; min-height: 1px; height: 1px; align-self: auto; }
}

@media (max-width: 576px) {
  .footer-cta h2 { font-size: 22px; }
  .footer-grid-3, .footer-grid-4 { grid-template-columns: 1fr; gap: 30px; }
  .footer-security-grid { flex-direction: column; }
  .footer-bottom-grid { flex-direction: column; text-align: center; }
  .footer-legal a { margin: 0 8px; }
}

.footer-parceiro-block { margin-top: 20px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.12); display: flex; flex-direction: column; gap: 10px; }
.footer-parceiro-label { font-size: 11px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: rgba(230,242,237,0.55); }
.footer-parceiro-link { display: inline-block; transition: opacity .2s, transform .2s; }
.footer-parceiro-link:hover { opacity: .85; transform: translateY(-2px); }
.footer-parceiro-logo { display: block; max-width: 160px; height: auto; filter: brightness(1.1) drop-shadow(0 1px 4px rgba(0,0,0,.35)); border-radius: 4px; }
