.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 15px 26px;
  text-align: center;
}
.btn--outline { border: 1px solid var(--ink); color: var(--ink); background: var(--white); }
.btn--solid { background: var(--coral); color: #3a2418; }
.btn--block { display: flex; width: 100%; }
.btn--ver { margin: 22px 16px 0; }

.ph { width: 100%; height: 100%; object-fit: cover; background: var(--ph); }

.bimg { width: 100%; height: auto; display: block; background: var(--ph); }
.banner-img { display: block; }
.carousel--banner .carousel__track { padding: 0; gap: 0; }

.badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
}
.badge--discount { background: var(--coral); color: #3a2418; padding: 6px 12px; }
.badge--lancamento {
  background: var(--coral-soft);
  color: var(--coral-strong);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 5px 14px;
  border-radius: 20px;
  font-size: 10px;
}
.badge--new {
  background: var(--white);
  color: var(--coral-strong);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 4px 12px;
  border-radius: 14px;
  font-size: 10px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.08);
}

.carousel { position: relative; }
.carousel__track {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 0 16px;
}
.carousel__track::-webkit-scrollbar { display: none; }
.carousel__slide { flex: 0 0 100%; scroll-snap-align: start; }

.carousel--cats .carousel__slide { flex: 0 0 46%; }
.carousel--cats .carousel__track { padding: 0 16px; }

.carousel__arrow {
  position: absolute;
  top: 42%;
  transform: translateY(-50%);
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--white);
  box-shadow: 0 2px 10px rgba(0,0,0,0.12);
  display: grid;
  place-items: center;
  z-index: 4;
  color: var(--ink);
}
.carousel__arrow .icon { width: 18px; height: 18px; }
.carousel__arrow--prev { left: 6px; }
.carousel__arrow--next { right: 6px; }

.carousel__dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  margin-top: 18px;
}
.carousel__dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #d6d2cc;
  transition: background 0.2s ease, transform 0.2s ease;
}
.carousel__dot.is-active { background: #4a4a4a; transform: scale(1.05); }

.catcard { display: block; }
.catcard__media {
  aspect-ratio: 1 / 1;
  background: var(--ph);
  overflow: hidden;
}
.catcard__label {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  text-align: center;
  letter-spacing: 0.03em;
  margin-top: 14px;
}

.pcard {
  display: block;
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
  padding: 18px 18px 26px;
  position: relative;
}
.pcard__badge { position: absolute; top: 18px; left: 0; z-index: 2; }
.pcard__media { aspect-ratio: 3 / 4; display: grid; place-items: center; }
.pcard__media img { width: 70%; height: 70%; object-fit: contain; background: transparent; }
.pcard__tag {
  display: inline-block;
  border: 1px solid var(--line-strong);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  padding: 5px 14px;
  margin: 4px auto 0;
}
.pcard__lancamento { margin: 4px auto 0; }
.pcard__center { text-align: center; }
.pcard__name {
  font-family: var(--font-display);
  font-size: 21px;
  font-weight: 600;
  line-height: 1.25;
  margin-top: 16px;
  min-height: 2.5em;
}
.pcard__price { margin-top: 18px; }
.pcard__price > span { display: block; }
.price__old { font-size: 13px; color: var(--muted); text-decoration: line-through; }
.price__now { font-size: 19px; font-weight: 700; color: var(--ink); margin-top: 2px; }
.price__inst { font-size: 13px; color: var(--muted); margin-top: 4px; }

.collections { padding: 0 16px; }
.col-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.col-tile { background: #f3f1ee; position: relative; }
.col-tile--wide { grid-column: 1 / -1; display: flex; align-items: stretch; }
.col-tile__media { position: relative; }
.col-tile:not(.col-tile--wide) .col-tile__media { aspect-ratio: 1 / 1; }
.col-tile--wide .col-tile__media { flex: 1; aspect-ratio: auto; min-height: 200px; }
.col-tile__new { position: absolute; top: 12px; left: 50%; transform: translateX(-50%); z-index: 2; }
.col-tile__body { padding: 14px 12px 18px; text-align: center; }
.col-tile--wide .col-tile__body {
  flex: 0 0 42%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.col-tile__kicker { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); }
.col-tile__name {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 600;
  letter-spacing: 0.06em;
  margin-top: 6px;
  display: inline-block;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 3px;
}

.benefits {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 34px 18px;
  padding: 0 22px;
}
.benefit { text-align: center; }
.benefit__icon { display: grid; place-items: center; height: 40px; margin-bottom: 12px; }
.benefit__icon .icon { width: 34px; height: 34px; stroke-width: 1.4; }
.benefit__icon img { width: 40px; height: 40px; object-fit: contain; }
.benefit__title { font-family: var(--font-display); font-size: 19px; font-weight: 600; }
.benefit__text { font-size: 12px; color: var(--ink-soft); margin-top: 6px; line-height: 1.45; }

.locator { padding: 0 22px; max-width: 420px; margin: 0 auto; }
.locator__field { margin-bottom: 16px; }
.locator__label { font-size: 13px; margin-bottom: 7px; }
.locator__label b { color: var(--coral-strong); font-weight: 700; }
.select {
  position: relative;
  display: flex;
  align-items: center;
  border: 1px solid var(--line-strong);
  border-radius: 4px;
  height: 50px;
}
.select select {
  flex: 1;
  border: 0;
  background: none;
  outline: none;
  padding: 0 14px;
  height: 100%;
  color: var(--muted);
  -webkit-appearance: none;
  appearance: none;
}
.select .icon { width: 20px; height: 20px; color: var(--coral); margin-right: 12px; pointer-events: none; }
.locator__btn { margin-top: 6px; }

.backtotop { text-align: center; padding: 30px 0 34px; }
.backtotop__btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--coral);
  color: #fff;
  display: inline-grid;
  place-items: center;
  margin-bottom: 12px;
}
.backtotop__btn .icon { width: 18px; height: 18px; }
.backtotop__label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--coral-strong);
}
