/* ============================================
   components.css — botones, chips, badges, cards
   ============================================ */

/* -------------------- Botones -------------------- */
.btn {
  --btn-bg: var(--c-blue);
  --btn-fg: var(--c-cream);
  --btn-shadow: 6px 6px 0 var(--c-terracotta);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 26px;
  background: var(--btn-bg);
  color: var(--btn-fg);
  font-family: var(--ff-body);
  font-weight: 600;
  font-size: var(--fs-sm);
  letter-spacing: 0.02em;
  border: 1.5px solid var(--c-blue);
  box-shadow: var(--btn-shadow);
  transition: transform var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out),
              background var(--dur) var(--ease-out);
  cursor: pointer;
  text-align: center;
  line-height: 1.1;
}
.btn:hover {
  transform: translate(-2px, -2px);
  box-shadow: 9px 9px 0 var(--c-terracotta);
}
.btn:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--c-terracotta);
}

.btn--terra {
  --btn-bg: var(--c-terracotta);
  --btn-fg: var(--c-cream);
  --btn-shadow: 6px 6px 0 var(--c-blue);
}
.btn--terra:hover { box-shadow: 9px 9px 0 var(--c-blue); }
.btn--terra:active{ box-shadow: 2px 2px 0 var(--c-blue); }

.btn--mustard {
  --btn-bg: var(--c-mustard);
  --btn-fg: var(--c-blue);
  --btn-shadow: 6px 6px 0 var(--c-blue);
}

.btn--wa {
  --btn-bg: var(--c-wa-green);
  --btn-fg: white;
  --btn-shadow: 6px 6px 0 var(--c-blue);
}

.btn--ghost {
  --btn-bg: transparent;
  --btn-fg: var(--c-blue);
  border: 1.6px dashed var(--c-blue);
  box-shadow: none;
}
.btn--ghost:hover {
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 var(--c-blue);
  background: var(--c-bone);
}
.btn--ghost:active { box-shadow: 1px 1px 0 var(--c-blue); transform: translate(1px,1px); }

.btn--small { padding: 9px 16px; font-size: var(--fs-xs); }
.btn--large { padding: 18px 32px; font-size: var(--fs-base); }

/* -------------------- Chips -------------------- */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: var(--c-bone);
  border: 1.2px dotted var(--c-blue);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--c-blue);
}
.chip__check {
  width: 16px; height: 16px; flex: none;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--c-sage);
  color: var(--c-cream);
  font-size: 11px;
  font-weight: 700;
  border-radius: 50%;
}

/* -------------------- Badges -------------------- */
.badge {
  display: inline-block;
  padding: 4px 10px;
  font-family: var(--ff-body);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border: 1.2px solid currentColor;
  color: var(--c-blue);
  background: var(--c-bone);
}
.badge--terra { color: var(--c-terracotta); }
.badge--sage  { color: var(--c-sage); }
.badge--mustard { color: var(--c-mustard); }

/* -------------------- Card base -------------------- */
.card {
  background: var(--c-bone);
  border: 1.5px solid var(--c-blue);
  padding: var(--sp-6);
  box-shadow: var(--sh-hard);
  position: relative;
  transition: transform var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out);
}
.card--no-shadow { box-shadow: none; }

/* -------------------- Polaroid -------------------- */
.polaroid {
  background: var(--c-bone);
  padding: 12px 12px 36px;
  box-shadow: var(--sh-hard);
  border: 1px solid var(--c-blue-12);
  position: relative;
  transition: transform var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out);
}
.polaroid__img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  filter: saturate(0.92) contrast(0.95);
}
.polaroid__caption {
  position: absolute;
  left: 0; right: 0;
  bottom: 6px;
  text-align: center;
  font-family: var(--ff-hand);
  color: var(--c-blue);
  font-size: 1.2rem;
}
.polaroid__tape {
  position: absolute;
  top: -14px;
  left: 50%;
  width: 110px; height: 28px;
  transform: translateX(-50%) rotate(-3deg);
  background: url("../assets/svg/washi-tape.svg") center/100% 100% no-repeat;
  opacity: 0.92;
  filter: drop-shadow(1px 2px 0 rgba(14, 42, 71, 0.18));
}

/* Whatsapp link reusable */
.wa-link { color: var(--c-wa-dark); font-weight: 600; }
.wa-link:hover { color: var(--c-terracotta); }
