/* =============================================
   INTER — Auto-hospedada (sem Google Fonts)
   ============================================= */
@font-face { font-family:'Inter'; font-style:normal; font-weight:400; font-display:swap; src:url('../fonts/inter-latin-400-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:500; font-display:swap; src:url('../fonts/inter-latin-500-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:600; font-display:swap; src:url('../fonts/inter-latin-600-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:700; font-display:swap; src:url('../fonts/inter-latin-700-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:800; font-display:swap; src:url('../fonts/inter-latin-800-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }

/* =============================================
   OPPERMANN — CSS Principal
   Identidade: Azul #3B5FA5 | Cinza #555 | Branco
   ============================================= */

:root {
  --blue:        #3B5FA5;
  --blue-dark:   #2A4580;
  --blue-light:  #EEF2FB;
  --gray:        #555555;
  --gray-mid:    #888888;
  --gray-light:  #F5F6F8;
  --border:      #E0E4ED;
  --white:       #FFFFFF;
  --black:       #1A1A2E;
  --tramontina:  #CC0000;
  --radius:      10px;
  --radius-lg:   16px;
  --shadow:      0 2px 16px rgba(59,95,165,.10);
  --shadow-lg:   0 8px 40px rgba(59,95,165,.18);
  --font:        'Inter', system-ui, -apple-system, sans-serif;
  --transition:  .2s ease;
  --header-h:    72px;
}

/* RESET */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font); color: var(--black); background: var(--white); line-height: 1.6; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, select, textarea { font-family: inherit; font-size: 1rem; }

/* ACESSIBILIDADE */
.skip-to-content {
  position: absolute;
  top: -100%;
  left: 16px;
  background: var(--blue);
  color: #fff;
  padding: 10px 20px;
  border-radius: 0 0 8px 8px;
  font-weight: 600;
  font-size: .9rem;
  z-index: 99999;
  transition: top .2s;
}
.skip-to-content:focus { top: 0; }

:focus-visible {
  outline: 3px solid var(--blue);
  outline-offset: 3px;
  border-radius: 4px;
}
:focus:not(:focus-visible) { outline: none; }

/* UTILITIES */
.container        { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.container-narrow { max-width: 780px; }
.bg-light         { background: var(--gray-light); }
.bg-blue          { background: var(--blue); color: var(--white); }
.text-center      { text-align: center; }
.py-12            { padding-top: 3rem; padding-bottom: 3rem; }
.mt-8             { margin-top: 2rem; }
.section          { padding: 72px 0; }

/* =============================================
   BUTTONS
   ============================================= */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 28px;
  border-radius: var(--radius);
  font-weight: 600;
  font-size: .95rem;
  letter-spacing: .01em;
  transition: all var(--transition);
  white-space: nowrap;
}
.btn-lg    { padding: 15px 36px; font-size: 1.05rem; }
.btn-block { width: 100%; }

.btn-primary {
  background: var(--blue);
  color: var(--white);
  box-shadow: 0 2px 8px rgba(59,95,165,.3);
}
.btn-primary:hover { background: var(--blue-dark); box-shadow: 0 4px 16px rgba(59,95,165,.4); transform: translateY(-1px); }

.btn-outline {
  background: transparent;
  color: var(--white);
  border: 2px solid rgba(255,255,255,.7);
}
.btn-outline:hover { background: rgba(255,255,255,.12); border-color: var(--white); }

.btn-outline-white {
  background: transparent;
  color: var(--white);
  border: 2px solid rgba(255,255,255,.5);
  font-size: .88rem;
  padding: 9px 20px;
}
.btn-outline-white:hover { background: rgba(255,255,255,.15); border-color: var(--white); }

.btn-white {
  background: var(--white);
  color: var(--blue);
  font-weight: 700;
}
.btn-white:hover { background: #f0f4ff; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(0,0,0,.15); }

/* =============================================
   HEADER
   ============================================= */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--header-h);
  background: var(--white);
  box-shadow: 0 1px 0 var(--border);
  transition: box-shadow var(--transition);
}
.site-header.scrolled { box-shadow: var(--shadow); }

.header-inner {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.site-branding {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 16px;
}

.logo-img {
  height: 52px;
  width: auto;
  max-width: 220px;
  object-fit: contain;
}

.site-logo-text { font-size: 1.4rem; font-weight: 700; color: var(--blue); }

/* Bloco "Representante Oficial Tramontina" no header */
.header-parceria {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  padding-left: 16px;
  border-left: 1px solid var(--border);
}

.parceria-label {
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--gray-mid);
  white-space: nowrap;
}

.logo-tramontina {
  height: 26px;
  width: auto;
  object-fit: contain;
}

.nav-menu {
  display: flex;
  align-items: center;
  gap: 4px;
}
.nav-menu li a {
  padding: 8px 14px;
  border-radius: 8px;
  font-size: .93rem;
  font-weight: 500;
  color: var(--gray);
  transition: all var(--transition);
}
.nav-menu li a:hover     { color: var(--blue); background: var(--blue-light); }
.nav-menu li.current-menu-item > a { color: var(--blue); background: var(--blue-light); font-weight: 600; }

.nav-menu .nav-cta {
  background: var(--blue);
  color: var(--white) !important;
  padding: 9px 18px;
  border-radius: var(--radius);
  margin-left: 8px;
}
.nav-menu .nav-cta:hover { background: var(--blue-dark); }

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 6px;
}
.nav-toggle span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--gray);
  border-radius: 2px;
  transition: all var(--transition);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* =============================================
   HERO
   ============================================= */
.hero {
  min-height: 100vh;
  background: var(--blue-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  padding-top: var(--header-h);
}

/* Slides de fundo */
.hero-slides { position: absolute; inset: 0; z-index: 0; }
.hero-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.2s ease;
}
.hero-slide.active { opacity: 1; }
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(30,50,100,.88) 0%, rgba(59,95,165,.78) 100%);
  z-index: 0;
}
.hero-content, .hero-scroll-indicator { position: relative; z-index: 1; }

.hero-content {
  color: var(--white);
  max-width: 720px;
}
.hero-badge {
  display: inline-block;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.35);
  color: var(--white);
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 20px;
  margin-bottom: 20px;
  backdrop-filter: blur(4px);
}
.hero-location {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  color: rgba(255,255,255,.9);
  font-size: .88rem;
  font-weight: 500;
  margin-top: 10px;
  margin-bottom: 16px;
}

.hero-content h1 {
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 700;
  line-height: 1.15;
  margin-bottom: 20px;
}
.hero-content p {
  font-size: clamp(1rem, 2vw, 1.2rem);
  opacity: .88;
  margin-bottom: 36px;
  line-height: 1.7;
}
.hero-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

.hero-scroll-indicator {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,.6);
  animation: bounce 2s infinite;
}
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(8px)} }

/* =============================================
   DIFERENCIAIS
   ============================================= */
.diferenciais-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.diferencial-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px 24px;
  text-align: center;
  transition: all var(--transition);
}
.diferencial-card:hover { border-color: var(--blue); box-shadow: var(--shadow); transform: translateY(-3px); }
.diferencial-icon {
  width: 64px; height: 64px;
  background: var(--blue-light);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 16px;
  color: var(--blue);
}
.diferencial-card h3 { font-size: 1rem; font-weight: 600; margin-bottom: 8px; }
.diferencial-card p  { font-size: .9rem; color: var(--gray-mid); line-height: 1.6; }

/* =============================================
   SOBRE
   ============================================= */
.sobre-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.section-eyebrow {
  display: inline-block;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 12px;
}
.sobre-content h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 700; margin-bottom: 16px; line-height: 1.25; }
.sobre-content p  { color: var(--gray); margin-bottom: 16px; line-height: 1.7; }
.sobre-stats      { display: flex; gap: 32px; margin-top: 32px; padding-top: 32px; border-top: 1px solid var(--border); }
.stat strong      { display: block; font-size: 1.8rem; font-weight: 700; color: var(--blue); }
.stat span        { font-size: .82rem; color: var(--gray-mid); }
.sobre-image      { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/3; background: var(--gray-light); }
.sobre-image img  { width: 100%; height: 100%; object-fit: cover; }
.sobre-image-placeholder { background: linear-gradient(135deg, var(--blue-light), #dce6ff); }

/* =============================================
   SECTION HEADER
   ============================================= */
.section-header { margin-bottom: 48px; }
.section-header h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 700; margin-bottom: 12px; }
.section-header p  { color: var(--gray-mid); font-size: 1.05rem; max-width: 520px; margin: 0 auto; }

/* =============================================
   PRODUTOS GRID
   ============================================= */
.produtos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.produtos-grid-full { grid-template-columns: repeat(4, 1fr); }

.produto-card {
  display: block;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--transition);
  color: inherit;
  text-decoration: none;
}
.produto-card:hover { border-color: var(--blue); box-shadow: var(--shadow); transform: translateY(-3px); }
.produto-img { aspect-ratio: 1; overflow: hidden; background: var(--gray-light); position: relative; }
.produto-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.produto-card:hover .produto-img img { transform: scale(1.05); }
.produto-img-overlay {
  position: absolute;
  inset: 0;
  background: rgba(59,95,165,.72);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .25s ease;
  pointer-events: none;
}
.produto-card:hover .produto-img-overlay { opacity: 1; }
.produto-img-overlay span {
  color: #fff;
  font-weight: 600;
  font-size: .9rem;
  letter-spacing: .02em;
  display: flex;
  align-items: center;
  gap: 6px;
}
.produto-info { padding: 16px; }
.produto-info h3 { font-size: .95rem; font-weight: 600; margin-bottom: 4px; }
.produto-info p  { font-size: .85rem; color: var(--gray-mid); }
.produto-categoria {
  display: inline-block;
  margin-top: 8px;
  font-size: .75rem;
  font-weight: 600;
  color: var(--blue);
  background: var(--blue-light);
  padding: 3px 10px;
  border-radius: 20px;
}

/* =============================================
   CTA SECTION
   ============================================= */
.section-cta .cta-box {
  background: linear-gradient(135deg, var(--blue-dark), var(--blue));
  border-radius: var(--radius-lg);
  padding: 64px 48px;
  text-align: center;
  color: var(--white);
}
.cta-content h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 700; margin-bottom: 16px; }
.cta-content p  { font-size: 1.05rem; opacity: .88; margin-bottom: 32px; max-width: 520px; margin-left: auto; margin-right: auto; }

.section-cta.bg-blue { padding: 72px 0; }
.section-cta.bg-blue h2 { font-size: clamp(1.6rem, 3vw, 2rem); font-weight: 700; margin-bottom: 12px; }
.section-cta.bg-blue p  { opacity: .88; margin-bottom: 28px; }

/* =============================================
   PAGE HERO
   ============================================= */
.page-hero {
  background: linear-gradient(135deg, var(--blue-dark), var(--blue));
  color: var(--white);
  padding: calc(var(--header-h) + 56px) 0 56px;
  text-align: center;
}
.page-hero .section-eyebrow { color: rgba(255,255,255,.75); margin-bottom: 8px; }
.page-hero h1 { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 700; margin-bottom: 12px; }
.page-hero p  { font-size: 1.05rem; opacity: .88; max-width: 540px; margin: 0 auto; }
.page-hero-small { padding: calc(var(--header-h) + 32px) 0 32px; }
.page-hero-revendedor {
  background: linear-gradient(135deg, var(--blue-dark) 0%, #4a7abf 100%);
  padding: calc(var(--header-h) + 48px) 0 56px;
}

/* FAQ */
.section-faq { background: var(--white); }
.faq-list { max-width: 720px; margin: 40px auto 0; display: flex; flex-direction: column; gap: 12px; }
.faq-item {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.faq-question {
  width: 100%;
  text-align: left;
  padding: 18px 22px;
  font-weight: 600;
  font-size: .97rem;
  color: var(--black);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  background: var(--white);
  transition: background var(--transition);
}
.faq-question:hover { background: var(--gray-light); }
.faq-question[aria-expanded="true"] { background: var(--blue-light); color: var(--blue); }
.faq-icon {
  flex-shrink: 0;
  width: 20px; height: 20px;
  transition: transform .25s ease;
}
.faq-question[aria-expanded="true"] .faq-icon { transform: rotate(45deg); }
.faq-answer {
  padding: 0 22px;
  max-height: 0;
  overflow: hidden;
  transition: max-height .3s ease, padding .3s ease;
  font-size: .95rem;
  color: var(--gray);
  line-height: 1.7;
}
.faq-answer.open { max-height: 200px; padding: 0 22px 18px; }

/* =============================================
   FILTROS CATEGORIAS
   ============================================= */
.filtros-categorias {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 40px;
}
.filtro-btn {
  padding: 8px 20px;
  border-radius: 20px;
  font-size: .88rem;
  font-weight: 500;
  color: var(--gray);
  border: 1px solid var(--border);
  background: var(--white);
  transition: all var(--transition);
}
.filtro-btn:hover, .filtro-btn.active {
  background: var(--blue);
  color: var(--white);
  border-color: var(--blue);
}

/* =============================================
   FORMULÁRIO REVENDEDOR
   ============================================= */
.form-beneficios {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 40px;
}
.beneficio {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .92rem;
  font-weight: 500;
  color: var(--gray);
}
.beneficio-icon { color: var(--blue); font-weight: 700; font-size: 1rem; }

.form-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 48px 40px;
  box-shadow: var(--shadow);
}
.form-card h2 { font-size: 1.4rem; font-weight: 700; margin-bottom: 4px; }
.form-subtitle { color: var(--gray-mid); font-size: .9rem; margin-bottom: 32px; }
.required-mark { color: var(--tramontina); }

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.form-row-3 { grid-template-columns: 1fr 1fr auto; }
.form-group       { display: flex; flex-direction: column; gap: 6px; margin-bottom: 20px; }
.form-group-sm    { /* default */ }
.form-group-xs    { max-width: 100px; }

.form-group label { font-size: .88rem; font-weight: 600; color: var(--black); }

.form-group input,
.form-group select,
.form-group textarea {
  padding: 11px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  background: var(--white);
  color: var(--black);
  transition: border-color var(--transition), box-shadow var(--transition);
  width: 100%;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(59,95,165,.12);
}
.form-group textarea { resize: vertical; min-height: 100px; }

.field-error { font-size: .8rem; color: var(--tramontina); min-height: 16px; }
.form-group.has-error input,
.form-group.has-error select { border-color: var(--tramontina); }

.form-submit { margin-top: 8px; }

.form-feedback {
  margin-top: 16px;
  padding: 14px 18px;
  border-radius: var(--radius);
  font-size: .92rem;
  font-weight: 500;
}
.form-feedback.success { background: #e8f5e9; color: #2e7d32; border: 1px solid #a5d6a7; }
.form-feedback.error   { background: #ffebee; color: #c62828; border: 1px solid #ef9a9a; }

/* =============================================
   FOOTER
   ============================================= */
.site-footer {
  background: var(--black);
  color: rgba(255,255,255,.75);
  padding: 64px 0 0;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.footer-logo {
  height: 56px;
  width: auto;
  margin-bottom: 16px;
  background: #fff;
  padding: 8px 14px;
  border-radius: 10px;
  box-sizing: content-box;
}
.footer-logo-text { font-size: 1.4rem; font-weight: 700; color: var(--white); display: block; margin-bottom: 12px; }

.footer-tramontina-logo {
  height: 28px;
  width: auto;
  object-fit: contain;
  margin-bottom: 14px;
  background: #fff;
  padding: 8px 14px;
  border-radius: 10px;
  box-sizing: content-box;
}
.footer-brand p   { font-size: .9rem; line-height: 1.7; }

.footer-col h4 {
  color: var(--white);
  font-size: .88rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.footer-col ul li { margin-bottom: 10px; }
.footer-col ul li a { font-size: .9rem; transition: color var(--transition); }
.footer-col ul li a:hover { color: var(--white); }

.footer-contact li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .9rem;
  margin-bottom: 12px;
}
.footer-contact svg { flex-shrink: 0; margin-top: 2px; opacity: .6; }

.footer-parceria  { font-size: .88rem; line-height: 1.6; margin-bottom: 16px; }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  font-size: .82rem;
  color: rgba(255,255,255,.45);
}
.footer-bottom strong { color: rgba(255,255,255,.65); }
.footer-bottom-links { display: flex; align-items: center; gap: 10px; font-size: .82rem; color: rgba(255,255,255,.45); }
.footer-bottom-links a { color: rgba(255,255,255,.55); text-decoration: none; transition: color var(--transition); }
.footer-bottom-links a:hover { color: rgba(255,255,255,.9); }

/* =============================================
   PAGE CONTENT
   ============================================= */
.page-content { max-width: 720px; margin: 0 auto; }
.page-content h2, .page-content h3 { font-weight: 700; margin: 1.5em 0 .5em; }
.page-content p  { color: var(--gray); margin-bottom: 1em; line-height: 1.7; }

/* =============================================
   COMO FUNCIONA
   ============================================= */
.section-como-funciona { background: var(--white); }
.steps-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: 0 16px;
  align-items: start;
  margin-top: 48px;
  margin-bottom: 40px;
}
.step {
  text-align: center;
  padding: 32px 24px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: var(--white);
  box-shadow: var(--shadow);
  position: relative;
}
.step-number {
  position: absolute;
  top: -16px;
  left: 50%;
  transform: translateX(-50%);
  width: 32px; height: 32px;
  background: var(--blue);
  color: #fff;
  border-radius: 50%;
  font-size: .82rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.step-icon {
  width: 64px; height: 64px;
  background: var(--blue-light);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 8px auto 20px;
  color: var(--blue);
}
.step h3 { font-weight: 700; margin-bottom: 10px; font-size: 1.05rem; }
.step p  { font-size: .9rem; color: var(--gray); line-height: 1.65; }
.step-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 56px;
  color: var(--gray-mid);
  opacity: .5;
}

@media (max-width: 768px) {
  .steps-grid {
    grid-template-columns: 1fr;
    gap: 32px 0;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
  }
  .step-arrow { padding-top: 0; transform: rotate(90deg); }
}

/* =============================================
   PÁGINA 404
   ============================================= */
.not-found-box {
  max-width: 540px;
  margin: 0 auto;
  padding: 48px 32px;
}
.not-found-code {
  font-size: clamp(5rem, 15vw, 9rem);
  font-weight: 800;
  color: var(--blue);
  line-height: 1;
  opacity: .12;
  margin-bottom: -16px;
  user-select: none;
}
.not-found-box h2 { font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 700; margin-bottom: 12px; }
.not-found-box > p { color: var(--gray); margin-bottom: 28px; line-height: 1.7; }
.not-found-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 40px; }
.not-found-links p  { font-size: .85rem; color: var(--gray-mid); margin-bottom: 10px; }
.not-found-links ul { list-style: none; display: flex; gap: 24px; justify-content: center; flex-wrap: wrap; }
.not-found-links a  { font-size: .9rem; color: var(--blue); text-decoration: none; font-weight: 500; }
.not-found-links a:hover { text-decoration: underline; }

/* =============================================
   PRODUTO INDIVIDUAL — WooCommerce summary layout
   ============================================= */
.page-hero-produto { padding-bottom: 40px; }

.produto-single-grid {
  display: grid;
  grid-template-columns: 55% 1fr;
  gap: 48px;
  align-items: start;
  margin-bottom: 64px;
}

/* Coluna imagem */
.product-images {
  position: sticky;
  top: calc(var(--header-h) + 24px);
}
.produto-single-img {
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  background: var(--white);
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
.produto-single-img .produto-foto {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 24px;
}
.produto-single-placeholder {
  width: 100%;
  height: 100%;
  min-height: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gray-mid);
}

/* Coluna resumo — product-summary */
.product-summary { display: flex; flex-direction: column; gap: 0; }
.produto-single-cats { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.produto-single-info h1,
.product-summary h1 {
  font-size: clamp(1.3rem, 2.5vw, 1.8rem); font-weight: 800; margin-bottom: 8px; line-height: 1.2;
  color: var(--black);
}
.produto-single-excerpt { font-size: .97rem; color: var(--gray); line-height: 1.7; margin-bottom: 16px; }
.produto-single-descricao { margin-bottom: 24px; }
.produto-single-codigo {
  font-size: .78rem; color: var(--gray-mid); letter-spacing: .02em; margin-bottom: 12px;
  font-family: 'Courier New', monospace; display: inline-flex; align-items: center; gap: 5px;
  background: var(--gray-light); padding: 5px 10px; border-radius: 6px;
}
.produto-summary-divider {
  border: none; border-top: 1px solid var(--border); margin: 16px 0;
}

/* Preço estilo WooCommerce */
.woo-price {
  font-size: 2rem; font-weight: 800; color: var(--blue);
  letter-spacing: -.02em; line-height: 1; display: block; margin-bottom: 10px;
}
.produto-single-estoque {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: .82rem; padding: 4px 10px; border-radius: 20px; font-weight: 600;
  background: #ECFDF5; color: #065F46; margin-bottom: 20px;
}
.produto-single-estoque.zero { background: #FEF2F2; color: #991B1B; }

/* Linha qty + botão Adicionar — WooCommerce style */
.produto-single-cart { margin-bottom: 16px; }
.woo-add-to-cart-form {
  display: flex; align-items: stretch; gap: 10px; flex-wrap: wrap;
}
.qty-input-wrap {
  display: flex; align-items: center;
  border: 1.5px solid var(--border); border-radius: var(--radius);
  overflow: hidden; background: var(--white);
}
.qty-input-wrap .qty-btn-sm {
  width: 36px; height: 48px;
  background: var(--gray-light); color: var(--gray);
  font-size: 1.1rem; font-weight: 700; border: none;
  cursor: pointer; transition: background var(--transition);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.qty-input-wrap .qty-btn-sm:hover { background: var(--border); }
.qty-input-wrap input[type="number"] {
  width: 52px; height: 48px; text-align: center;
  font-size: 1rem; font-weight: 700; border: none;
  border-left: 1.5px solid var(--border); border-right: 1.5px solid var(--border);
  -moz-appearance: textfield;
}
.qty-input-wrap input[type="number"]::-webkit-inner-spin-button,
.qty-input-wrap input[type="number"]::-webkit-outer-spin-button { -webkit-appearance: none; }
.qty-input-wrap input[type="number"]:focus { outline: none; }

.woo-btn-add-single {
  flex: 1; min-width: 160px; height: 48px; padding: 0 24px;
  background: var(--blue); color: var(--white);
  border: none; border-radius: var(--radius);
  font-size: 1rem; font-weight: 700; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  transition: background var(--transition), transform var(--transition);
}
.woo-btn-add-single:hover { background: var(--blue-dark); transform: translateY(-1px); }
.woo-btn-add-single:disabled { opacity: .6; cursor: not-allowed; transform: none; }

/* Breadcrumb produto */
.produto-breadcrumb {
  display: flex; align-items: center; gap: 6px;
  font-size: .85rem; color: var(--gray-mid); flex-wrap: wrap;
}
.produto-breadcrumb a {
  color: var(--blue); text-decoration: none; display: inline-flex; align-items: center; gap: 4px;
  transition: color var(--transition);
}
.produto-breadcrumb a:hover { color: var(--blue-dark); text-decoration: underline; }
.produto-breadcrumb-sep { color: var(--border); }
.produto-breadcrumb-current { color: var(--gray); font-weight: 500; }

.qtd-ctrl-lg { display: inline-flex; align-items: center; gap: 12px; }
.qtd-ctrl-lg .qtd-btn { width: 44px; height: 44px; font-size: 1.3rem; }
.qtd-ctrl-lg .qtd-valor { font-size: 1.2rem; font-weight: 700; min-width: 32px; text-align: center; }
.produto-single-descricao { margin-bottom: 24px; }

.produto-single-aviso {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .85rem;
  color: var(--gray-mid);
  margin-bottom: 16px;
}
.produto-single-cta { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
.btn-whatsapp {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #25D366;
  color: #fff;
  padding: 12px 22px;
  border-radius: 8px;
  font-weight: 600;
  font-size: .95rem;
  text-decoration: none;
  transition: background var(--transition);
}
.btn-whatsapp:hover { background: #1ebe5c; }

.produto-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding-top: 40px;
  border-top: 1px solid var(--border);
}
.produto-nav-item { flex: 1; }
.produto-nav-item a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--black);
  text-decoration: none;
  font-weight: 600;
  font-size: .92rem;
  transition: color var(--transition);
}
.produto-nav-item a:hover { color: var(--blue); }
.produto-nav-item a span { display: flex; flex-direction: column; }
.produto-nav-item a small { font-size: .75rem; font-weight: 400; color: var(--gray-mid); }
.produto-nav-next { text-align: right; justify-content: flex-end; display: flex; }
.produto-nav-next a { flex-direction: row-reverse; }

@media (max-width: 768px) {
  .produto-single-grid { grid-template-columns: 1fr; gap: 28px; }
  .product-images { position: static; }
  .produto-single-cta .btn { width: 100%; justify-content: center; }
  .produto-nav { flex-direction: column; gap: 16px; }
  .produto-nav-next { justify-content: flex-start; }
  .woo-add-to-cart-form { flex-direction: column; }
  .woo-btn-add-single { width: 100%; }
}

/* =============================================
   SCROLL ANIMATIONS
   ============================================= */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .55s ease, transform .55s ease;
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }
.reveal-delay-4 { transition-delay: .4s; }

/* Admin bar compensation */
.admin-bar .site-header { top: 32px; }
@media (max-width: 782px) { .admin-bar .site-header { top: 46px; } }

/* =============================================
   LOJA — Catálogo, Carrinho, Checkout, Pedidos
   ============================================= */

/* Banner lojista */
.lojista-banner {
  background: var(--blue);
  color: var(--white);
  padding: 14px 0;
}
.lojista-banner p { color: rgba(255,255,255,.92); font-size: .93rem; }
.lojista-banner .btn-outline { border-color: rgba(255,255,255,.6); color: var(--white); }

/* Tabs registro */
.lojista-tabs { display: flex; gap: 0; margin-bottom: 24px; border-bottom: 2px solid var(--border); }
.lojista-tab {
  padding: 10px 24px; font-weight: 600; font-size: .95rem;
  color: var(--gray-mid); border-bottom: 2px solid transparent; margin-bottom: -2px;
  background: none; cursor: pointer; transition: all var(--transition);
}
.lojista-tab.active { color: var(--blue); border-bottom-color: var(--blue); }

/* Filtro de categorias */
.catalogo-categorias-wrap {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding: 10px 0;
  position: sticky;
  top: var(--header-h);
  z-index: 99;
}
.catalogo-categorias {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}
.cat-pill {
  display: inline-flex;
  align-items: center;
  padding: 5px 14px;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: var(--white);
  color: var(--gray);
  font-size: .8rem;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--transition);
  font-family: var(--font);
}
.cat-pill:hover {
  border-color: var(--blue);
  color: var(--blue);
  background: var(--blue-light);
}
.cat-pill.active {
  background: var(--blue);
  border-color: var(--blue);
  color: var(--white);
  font-weight: 600;
}

/* Barra do catálogo */
.catalogo-topbar {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding: 12px 0;
  position: sticky;
  top: calc(var(--header-h) + 45px);
  z-index: 100;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.catalogo-topbar-inner {
  display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
.catalogo-busca-wrap {
  position: relative; flex: 1; max-width: 480px; min-width: 200px;
}
.catalogo-busca-wrap svg {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--gray-mid); pointer-events: none;
}
.catalogo-busca-input {
  width: 100%; padding: 10px 14px 10px 40px;
  border: 1.5px solid var(--border); border-radius: var(--radius);
  font-size: .93rem; transition: border-color var(--transition), box-shadow var(--transition);
  background: var(--gray-light);
}
.catalogo-busca-input:focus {
  outline: none; border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(59,95,165,.12);
  background: var(--white);
}
.catalogo-busca-input::placeholder { color: var(--gray-mid); }
.catalogo-topbar-actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

/* Toggle "Mostrar indisponíveis" */
.filtro-estoque-toggle {
  display: inline-flex; align-items: center; gap: 8px;
  cursor: pointer; user-select: none;
}
.filtro-estoque-toggle input[type="checkbox"] { display: none; }
.filtro-estoque-track {
  width: 36px; height: 20px; border-radius: 10px;
  background: var(--border); position: relative;
  transition: background .2s ease; flex-shrink: 0;
}
.filtro-estoque-track::after {
  content: ''; position: absolute;
  top: 3px; left: 3px;
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--white);
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
  transition: transform .2s ease;
}
.filtro-estoque-toggle input:checked + .filtro-estoque-track { background: var(--blue); }
.filtro-estoque-toggle input:checked + .filtro-estoque-track::after { transform: translateX(16px); }
.filtro-estoque-label { font-size: .82rem; color: var(--gray); white-space: nowrap; }
.catalogo-info {
  font-size: .82rem; color: var(--gray-mid); margin-bottom: 20px;
  display: flex; align-items: center; gap: 6px;
}
.catalogo-info strong { color: var(--black); }

/* Badge contador carrinho */
.cart-count-badge {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--tramontina); color: var(--white);
  min-width: 20px; height: 20px; border-radius: 10px; padding: 0 5px;
  font-size: .7rem; font-weight: 700; margin-left: 4px;
  line-height: 1;
}
.cart-count-badge[data-zero="true"],
.cart-count-badge:empty { background: rgba(255,255,255,.3); }

/* Botão carrinho com badge */
.btn-cart-topbar {
  position: relative;
  display: inline-flex; align-items: center; gap: 8px;
}

/* Grid catálogo — 4 col desktop, 3 tablet, 2 mobile, 1 mini */
.catalogo-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
@media (max-width: 1100px) { .catalogo-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px)  { .catalogo-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; } }
@media (max-width: 400px)  { .catalogo-grid { grid-template-columns: 1fr; } }

/* Card catálogo — WooCommerce Storefront style */
.catalogo-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
  display: flex; flex-direction: column;
  position: relative; overflow: hidden;
}
.catalogo-card:hover {
  border-color: var(--blue);
  box-shadow: var(--shadow);
  transform: translateY(-3px);
}
/* Sem estoque — overlay */
.catalogo-card.sem-estoque {
  opacity: 1;
}
.catalogo-card.sem-estoque .catalogo-card-img::after {
  content: 'Indisponível';
  position: absolute;
  top: 8px; left: 8px;
  background: rgba(0,0,0,.55);
  color: #fff;
  font-size: .68rem; font-weight: 700; letter-spacing: .05em;
  padding: 3px 9px; border-radius: 20px;
  text-transform: uppercase;
  z-index: 2;
}
.catalogo-card.sem-estoque .catalogo-card-img { position: relative; }
.catalogo-card.sem-estoque .catalogo-card-img img { opacity: .45; filter: grayscale(1); }

/* Imagem quadrada 1:1 */
.catalogo-card-img {
  width: 100%; aspect-ratio: 1/1; overflow: hidden;
  background: var(--gray-light);
  position: relative;
}
.catalogo-card-img img {
  width: 100%; height: 100%; object-fit: contain; padding: 12px;
  transition: transform .3s ease;
}
.catalogo-card:hover .catalogo-card-img img { transform: scale(1.04); }

/* Sem imagem — placeholder */
.catalogo-card-img-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  color: var(--border);
}

.catalogo-card-body { padding: 12px 14px 14px; display: flex; flex-direction: column; flex: 1; }

/* Nome — 2 linhas max com ellipsis */
.catalogo-nome {
  font-size: .92rem; font-weight: 700; line-height: 1.35; color: var(--black);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; margin-bottom: 4px;
}
/* Código SKU discreto */
.catalogo-sku {
  font-size: .7rem; color: var(--gray-mid); margin-bottom: 6px;
  font-family: 'Courier New', monospace; letter-spacing: .02em;
}
.catalogo-desc {
  font-size: .78rem; color: var(--gray-mid); line-height: 1.45;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; margin-bottom: 8px;
}

.catalogo-footer {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; margin-top: auto; padding-top: 10px;
  border-top: 1px solid var(--border);
}
.catalogo-preco-wrap { display: flex; flex-direction: column; gap: 3px; }
.catalogo-preco {
  display: block; font-size: 1.15rem; font-weight: 800;
  color: var(--blue);
  letter-spacing: -.01em; line-height: 1;
}
.catalogo-estoque { display: block; font-size: .72rem; color: var(--gray-mid); margin-top: 1px; }
.catalogo-estoque.zero { color: var(--tramontina); font-weight: 600; }

/* Badge de promoção */
.promo-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  background: #B8860B;
  color: #fff;
  font-size: .68rem;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 4px;
  z-index: 3;
  letter-spacing: .03em;
  pointer-events: none;
  text-transform: uppercase;
}

/* Badge de estoque */
.estoque-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .7rem; font-weight: 600; padding: 2px 8px;
  border-radius: 20px; white-space: nowrap;
}
.estoque-badge.em-estoque { background: #ECFDF5; color: #065F46; }
.estoque-badge.sem-estoque-badge { background: #FEF2F2; color: #991B1B; }

/* Botão Adicionar ao carrinho — full width no card */
.woo-btn-cart {
  width: 100%; padding: 9px 12px; font-size: .85rem; font-weight: 600;
  background: var(--blue); color: var(--white);
  border: none; border-radius: var(--radius);
  cursor: pointer; transition: background var(--transition), transform var(--transition);
  display: flex; align-items: center; justify-content: center; gap: 6px;
  margin-top: 10px;
}
.woo-btn-cart:hover { background: var(--blue-dark); transform: translateY(-1px); }
.woo-btn-cart:disabled { opacity: .6; cursor: not-allowed; transform: none; }
.woo-btn-cart.adding { animation: cart-pop .35s ease; }

/* Link "Ver detalhes" para visitantes */
.catalogo-card-link-visitor {
  display: block; text-align: center;
  font-size: .82rem; font-weight: 600; color: var(--blue);
  margin-top: 10px; padding: 7px;
  border: 1.5px solid var(--border); border-radius: var(--radius);
  text-decoration: none; transition: all var(--transition);
}
.catalogo-card-link-visitor:hover { border-color: var(--blue); background: var(--blue-light); }

/* Controle de quantidade no card */
.qtd-ctrl-inner { display: flex; align-items: center; gap: 4px; }
.qtd-btn {
  width: 30px; height: 30px; border-radius: 8px;
  background: var(--blue-light); color: var(--blue);
  font-size: 1.1rem; font-weight: 700; display: flex; align-items: center; justify-content: center;
  cursor: pointer; border: 1.5px solid transparent; transition: all var(--transition);
  line-height: 1;
}
.qtd-btn:hover { background: var(--blue); color: var(--white); border-color: var(--blue); }
.qtd-btn:active { transform: scale(.92); }
.qtd-valor {
  font-weight: 700; font-size: .9rem; min-width: 24px; text-align: center;
  background: var(--white); border: 1.5px solid var(--border); border-radius: 6px;
  height: 30px; display: flex; align-items: center; justify-content: center;
}
.qtd-ctrl-lg .qtd-btn { width: 38px; height: 38px; font-size: 1.2rem; }
.qtd-ctrl-lg .qtd-valor { min-width: 36px; height: 38px; font-size: 1.05rem; }

/* Linha de ação abaixo do preço no card */
.catalogo-card-actions { margin-top: 10px; }

/* Skeleton loading */
@keyframes skeleton-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: .4; }
}
.catalogo-skeleton {
  background: var(--white); border: 1.5px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column;
}
.skeleton-img {
  aspect-ratio: 1/1; background: var(--gray-light);
  animation: skeleton-pulse 1.4s ease-in-out infinite;
}
.skeleton-body { padding: 10px 12px 12px; display: flex; flex-direction: column; gap: 8px; }
.skeleton-line {
  height: 12px; background: var(--gray-light); border-radius: 6px;
  animation: skeleton-pulse 1.4s ease-in-out infinite;
}
.skeleton-line.w80 { width: 80%; }
.skeleton-line.w50 { width: 50%; }
.skeleton-line.w65 { width: 65%; }

/* Botão carregar mais */
#btn-carregar-mais {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 32px; font-size: .95rem; font-weight: 600;
  border: 2px solid var(--blue); color: var(--blue);
  border-radius: var(--radius); background: var(--white);
  cursor: pointer; transition: all var(--transition);
}
#btn-carregar-mais:hover { background: var(--blue); color: var(--white); }
#btn-carregar-mais.loading { opacity: .7; pointer-events: none; }
#btn-carregar-mais .btn-mais-icon { transition: transform var(--transition); }
#btn-carregar-mais:hover .btn-mais-icon { transform: translateY(2px); }

/* Wrap carregar mais */
.catalogo-load-more-wrap { text-align: center; margin-top: 36px; padding-bottom: 16px; }
.catalogo-load-more-info { font-size: .82rem; color: var(--gray-mid); margin-top: 10px; }

/* Animação add-to-cart */
@keyframes cart-pop {
  0%   { transform: scale(1); }
  40%  { transform: scale(.88); }
  70%  { transform: scale(1.08); }
  100% { transform: scale(1); }
}
.btn-add-cart.adding { animation: cart-pop .35s ease; }
.btn-add-cart { transition: all var(--transition); }
.btn-add-cart:disabled { opacity: .6; cursor: not-allowed; }
.btn-add-cart:not(:disabled):hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(59,95,165,.3); }

/* DRAWER CARRINHO */
.cart-overlay {
  display: none; position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 1100;
}
.cart-overlay.open { display: block; }
.cart-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 380px; max-width: 100vw;
  background: var(--white); z-index: 1101;
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform .3s ease;
  box-shadow: -4px 0 32px rgba(0,0,0,.15);
}
.cart-drawer.open { transform: translateX(0); }
.cart-drawer-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px; border-bottom: 1px solid var(--border);
}
.cart-drawer-header h3 { font-size: 1.1rem; font-weight: 700; margin: 0; }
.cart-drawer-close {
  width: 32px; height: 32px; border-radius: 8px;
  background: var(--gray-light); color: var(--gray);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; cursor: pointer; border: none; transition: background var(--transition);
}
.cart-drawer-close:hover { background: var(--border); }
.cart-drawer-body { flex: 1; overflow-y: auto; padding: 16px 24px; }
.cart-drawer-footer { padding: 16px 24px; border-top: 1px solid var(--border); }
.cart-vazio { color: var(--gray-mid); text-align: center; padding: 32px 0; font-size: .93rem; }
.cart-lista { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.cart-item { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border); }
.cart-item-info { flex: 1; }
.cart-item-info strong { display: block; font-size: .9rem; font-weight: 600; margin-bottom: 3px; }
.cart-item-preco { font-size: .8rem; color: var(--gray-mid); }
.cart-item-acoes { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }
.cart-item-sub { font-size: .9rem; font-weight: 700; color: var(--blue); }
.cart-item-remover {
  background: none; border: none; color: var(--gray-mid); font-size: .8rem;
  cursor: pointer; padding: 2px; transition: color var(--transition);
}
.cart-item-remover:hover { color: var(--tramontina); }
.cart-total-row {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 1rem; margin-bottom: 14px;
}
.cart-total-row strong { font-size: 1.1rem; color: var(--blue); }

/* MODAL CHECKOUT */
.checkout-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.5);
  z-index: 1200; display: flex; align-items: center; justify-content: center; padding: 16px;
}
.checkout-modal {
  background: var(--white); border-radius: var(--radius-lg);
  width: 100%; max-width: 480px; max-height: 90vh; overflow-y: auto;
  box-shadow: var(--shadow-lg);
}
.checkout-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px; border-bottom: 1px solid var(--border);
}
.checkout-modal-header h3 { margin: 0; font-size: 1.1rem; }
.checkout-modal-body { padding: 24px; }
.checkout-info-loja {
  background: var(--blue-light); border-radius: var(--radius);
  padding: 14px 16px; margin-bottom: 20px;
}
.checkout-info-loja p { margin: 0 0 4px; font-size: .88rem; }
.checkout-total-box {
  background: var(--gray-light); border-radius: var(--radius);
  padding: 12px 16px; margin-bottom: 16px;
  font-size: .93rem; display: flex; justify-content: space-between; align-items: center;
}
.checkout-total-box strong { font-size: 1.1rem; color: var(--blue); }

/* btn outline azul pequeno */
.btn-outline-blue {
  background: transparent; color: var(--blue);
  border: 1.5px solid var(--blue); padding: 5px 12px;
  border-radius: var(--radius); font-size: .8rem; font-weight: 600;
  transition: all var(--transition);
}
.btn-outline-blue:hover { background: var(--blue); color: var(--white); }

/* PEDIDOS — histórico */
.pedidos-lista { display: flex; flex-direction: column; gap: 20px; }
.pedido-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; }
.pedido-card-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; background: var(--gray-light); border-bottom: 1px solid var(--border);
}
.pedido-numero { font-size: 1rem; font-weight: 700; margin-right: 12px; }
.pedido-data { font-size: .82rem; color: var(--gray-mid); }
.pedido-status {
  color: #fff; padding: 3px 10px; border-radius: 20px; font-size: .78rem; font-weight: 600;
}
.pedido-card-body { padding: 16px 20px; }
.pedido-itens-table { width: 100%; border-collapse: collapse; font-size: .88rem; margin-bottom: 12px; }
.pedido-itens-table th { text-align: left; padding: 6px 8px; color: var(--gray-mid); font-weight: 600; font-size: .78rem; border-bottom: 1px solid var(--border); }
.pedido-itens-table td { padding: 6px 8px; border-bottom: 1px solid var(--border); }
.pedido-itens-table td:nth-child(2), .pedido-itens-table th:nth-child(2) { text-align: center; }
.pedido-itens-table td:nth-child(3), .pedido-itens-table th:nth-child(3),
.pedido-itens-table td:nth-child(4), .pedido-itens-table th:nth-child(4) { text-align: right; }
.pedido-total { text-align: right; font-size: .95rem; margin-top: 6px; }
.pedido-obs { font-size: .83rem; color: var(--gray-mid); margin-top: 8px; }

@media (max-width: 768px) {
  .cart-drawer { width: 100%; }
  .catalogo-topbar-inner { flex-wrap: wrap; }
  .catalogo-busca-wrap { max-width: 100%; }
}
@media (max-width: 480px) {
  .catalogo-topbar-actions .btn span:not(.cart-count-badge) { display: none; }
}

/* Redução de movimento — acessibilidade */
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .hero-scroll-indicator { animation: none; }
  .hero-slide { transition: none; }
  .produto-card, .diferencial-card, .valor-card,
  .btn-primary, .btn-white, .btn-outline { transition: none; }
  .produto-card:hover,
  .diferencial-card:hover,
  .valor-card:hover      { transform: none; }
  .btn-primary:hover,
  .btn-white:hover       { transform: none; }
  .produto-img img       { transition: none; }
}

/* =============================================
   REDES SOCIAIS (FOOTER)
   ============================================= */
.footer-social { display: flex; gap: 10px; margin-top: 16px; }
.footer-social a {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: rgba(255,255,255,.1);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.7);
  transition: background var(--transition), color var(--transition);
}
.footer-social a:hover { background: rgba(255,255,255,.2); color: #fff; }

/* =============================================
   BANNER LGPD
   ============================================= */
.lgpd-banner {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 9998;
  background: var(--black);
  color: rgba(255,255,255,.88);
  padding: 16px 24px;
  box-shadow: 0 -4px 24px rgba(0,0,0,.2);
  animation: slideUp .3s ease;
}
@keyframes slideUp {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}
.lgpd-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.lgpd-banner p { font-size: .88rem; line-height: 1.5; margin: 0; }
.lgpd-banner a { color: #7eb3ff; text-decoration: underline; }
.lgpd-actions { display: flex; gap: 8px; flex-shrink: 0; }
.btn-sm { padding: 7px 14px; font-size: .83rem; display: inline-flex; align-items: center; gap: 5px; }

@media (max-width: 600px) {
  .lgpd-inner { flex-direction: column; align-items: flex-start; }
  .lgpd-actions { width: 100%; }
  .lgpd-actions .btn { flex: 1; text-align: center; }
}

/* =============================================
   WHATSAPP FLOAT
   ============================================= */
.whatsapp-float {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 10px;
  background: #25D366;
  color: #fff;
  border-radius: 50px;
  padding: 14px 20px 14px 16px;
  text-decoration: none;
  box-shadow: 0 4px 20px rgba(37,211,102,.45);
  font-weight: 600;
  font-size: .9rem;
  transition: transform .2s ease, box-shadow .2s ease, padding .2s ease;
  white-space: nowrap;
  overflow: hidden;
  max-width: 56px;
}
.whatsapp-float:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 32px rgba(37,211,102,.55);
  max-width: 280px;
}
.whatsapp-label {
  opacity: 0;
  max-width: 0;
  overflow: hidden;
  transition: opacity .2s ease .05s, max-width .2s ease;
  pointer-events: none;
}
.whatsapp-float:hover .whatsapp-label {
  opacity: 1;
  max-width: 200px;
}

@media (max-width: 480px) {
  .whatsapp-float { bottom: 16px; right: 16px; padding: 13px; border-radius: 50%; }
  .whatsapp-label { display: none; }
}

/* WhatsApp sobe quando banner LGPD está visível */
body.lgpd-visible .whatsapp-float { bottom: 96px; }
@media (max-width: 600px) { body.lgpd-visible .whatsapp-float { bottom: 148px; } }

/* =============================================
   LOCAL SEO BLOCK
   ============================================= */
.local-seo-block { max-width: 720px; margin: 0 auto; }
.local-seo-block h2 { font-size: clamp(1.15rem, 2vw, 1.35rem); font-weight: 700; color: var(--black); margin-bottom: 16px; }
.local-seo-block p  { color: var(--gray); margin-bottom: .9em; line-height: 1.75; font-size: .97rem; }
.local-seo-block p:last-child { margin-bottom: 0; }

/* =============================================
   PÁGINA SOBRE
   ============================================= */
.page-hero-sobre { background: linear-gradient(135deg, var(--blue-dark) 0%, var(--blue) 100%); }
.section-sobre-historia .sobre-content p { color: var(--gray); margin-bottom: 1em; line-height: 1.75; }

.numeros-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 40px;
}
.numero-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px 20px;
  text-align: center;
  box-shadow: var(--shadow);
}
.numero-card strong {
  display: block;
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 800;
  color: var(--blue);
  line-height: 1;
  margin-bottom: 8px;
}
.numero-card span { font-size: .88rem; color: var(--gray-mid); }

.valores-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 40px;
}
.valor-card {
  padding: 32px 24px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--white);
  box-shadow: var(--shadow);
  transition: transform var(--transition), box-shadow var(--transition);
}
.valor-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.valor-icon {
  width: 56px; height: 56px;
  background: var(--blue-light);
  border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  color: var(--blue);
  margin-bottom: 16px;
}
.valor-card h3 { font-size: 1.05rem; font-weight: 700; margin-bottom: 10px; }
.valor-card p  { font-size: .9rem; color: var(--gray); line-height: 1.65; }

/* =============================================
   PÁGINA CONTATO
   ============================================= */
.contato-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 56px;
  align-items: start;
}
.contato-info h2 { font-size: clamp(1.3rem, 2.5vw, 1.7rem); font-weight: 800; margin-bottom: 12px; }
.contato-info > p { color: var(--gray); margin-bottom: 32px; line-height: 1.7; }

.contato-lista { list-style: none; display: flex; flex-direction: column; gap: 24px; margin-bottom: 36px; }
.contato-lista li { display: flex; align-items: flex-start; gap: 16px; }
.contato-icon {
  width: 44px; height: 44px; flex-shrink: 0;
  background: var(--blue-light);
  border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  color: var(--blue);
}
.contato-lista strong { display: block; font-weight: 700; font-size: .95rem; margin-bottom: 4px; }
.contato-lista span  { font-size: .9rem; color: var(--gray); line-height: 1.55; }

.contato-parceria {
  padding-top: 28px;
  border-top: 1px solid var(--border);
  display: flex; align-items: center; gap: 16px;
}
.contato-parceria p { font-size: .8rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--gray-mid); margin: 0; }
.contato-logo-tramontina { height: 28px; width: auto; }

.contato-form-col .form-card { margin-top: 0; }

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 1024px) {
  .diferenciais-grid          { grid-template-columns: repeat(2, 1fr); }
  .sobre-grid                 { grid-template-columns: 1fr; gap: 40px; }
  .sobre-image                { order: -1; max-height: 320px; }
  .footer-grid                { grid-template-columns: 1fr 1fr; gap: 32px; }
  .produtos-grid-full         { grid-template-columns: repeat(3, 1fr); }
  .numeros-grid               { grid-template-columns: repeat(2, 1fr); }
  .valores-grid               { grid-template-columns: repeat(2, 1fr); }
  .contato-grid               { grid-template-columns: 1fr; gap: 40px; }
}

@media (max-width: 768px) {
  :root { --header-h: 64px; }
  .section { padding: 48px 0; }
  .header-parceria {
    padding-left: 10px;
    border-left: 1px solid var(--border);
    gap: 2px;
  }
  .parceria-label { font-size: .52rem; letter-spacing: .06em; }
  .logo-tramontina { height: 14px; }

  .site-nav { display: none; position: fixed; inset: var(--header-h) 0 0; background: var(--white); padding: 24px; overflow-y: auto; }
  .site-nav.open { display: block; }
  .nav-menu { flex-direction: column; align-items: stretch; gap: 4px; }
  .nav-menu li a { padding: 12px 16px; font-size: 1rem; border-radius: 8px; }
  .nav-menu .nav-cta { margin: 8px 0 0; text-align: center; }
  .nav-toggle { display: flex; }

  .logo-img              { height: 40px; width: auto; max-width: 170px; }
  .site-branding         { gap: 8px; }
  .hero-content h1       { font-size: 2rem; }
  .diferenciais-grid     { grid-template-columns: 1fr; gap: 16px; }
  .sobre-stats           { flex-wrap: wrap; gap: 20px; }
  .produtos-grid         { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .produtos-grid-full    { grid-template-columns: repeat(2, 1fr); }
  .form-row, .form-row-3 { grid-template-columns: 1fr; }
  .form-group-xs         { max-width: 100%; }
  .form-card             { padding: 28px 20px; }
  .form-beneficios       { gap: 10px; }
  .section-cta .cta-box  { padding: 40px 24px; }
  .footer-grid           { grid-template-columns: 1fr; gap: 28px; }
  .footer-bottom         { flex-direction: column; gap: 6px; text-align: center; }
  .numeros-grid          { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .valores-grid          { grid-template-columns: 1fr; }
  .contato-grid          { gap: 32px; }
}

@media (max-width: 480px) {
  .produtos-grid, .produtos-grid-full { grid-template-columns: 1fr; }
  .hero-actions { flex-direction: column; align-items: center; }
}
