/* ==========================================================================
   SALSAS CHILANGAS · COMPONENTS
   --------------------------------------------------------------------------
   Botones · Cards · Product card · Badges · Escala de picante · Formularios
   · Header · Footer · Hero · Benefits · FAQ
   Convención BEM ligera con prefijo sc-:
     .sc-bloque  ·  .sc-bloque--modificador  ·  .sc-bloque__parte
   ========================================================================== */


/* ==========================================================================
   1. BOTONES
   --------------------------------------------------------------------------
   El componente .sc-btn usa custom properties internas (--btn-*) para que las
   variantes solo cambien 3 valores. El "puente Elementor" más abajo hace que
   el widget Button herede el estilo de marca.
   ========================================================================== */
.sc-btn {
  --btn-bg: var(--green-500);
  --btn-fg: #fff;
  --btn-bd: var(--green-500);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55em;
  font-family: var(--font-body);
  font-size: var(--fs-cta);
  font-weight: var(--fw-bold);
  line-height: 1;
  letter-spacing: .01em;
  padding: 14px 24px;
  border-radius: var(--radius-pill);
  background: var(--btn-bg);
  color: var(--btn-fg);
  border: 2px solid var(--btn-bd);
  transition: transform var(--t-fast), background var(--t-base),
              box-shadow var(--t-base), border-color var(--t-base), color var(--t-base);
  white-space: nowrap;
  user-select: none;
  cursor: pointer;
}
.sc-btn:hover { transform: translateY(-2px); }
.sc-btn:active { transform: translateY(0); }
.sc-btn:focus-visible { box-shadow: var(--shadow-focus); outline: none; }
.sc-btn .sc-icon { width: 18px; height: 18px; }

.sc-btn--primary { --btn-bg: var(--green-500); --btn-fg: #fff; --btn-bd: var(--green-500); }
.sc-btn--primary:hover { --btn-bg: var(--green-600); --btn-bd: var(--green-600); box-shadow: 0 14px 30px -14px rgba(34,137,51,.6); }

.sc-btn--secondary { --btn-bg: var(--red-500); --btn-fg: #fff; --btn-bd: var(--red-500); }
.sc-btn--secondary:hover { --btn-bg: var(--red-600); --btn-bd: var(--red-600); box-shadow: var(--shadow-brand); }

.sc-btn--dark { --btn-bg: var(--ink-800); --btn-fg: var(--cream-50); --btn-bd: var(--ink-800); }
.sc-btn--dark:hover { --btn-bg: var(--ink-900); --btn-bd: var(--ink-900); }

.sc-btn--light { --btn-bg: var(--cream-50); --btn-fg: var(--ink-800); --btn-bd: var(--cream-50); }
.sc-btn--light:hover { --btn-bg: #fff; --btn-bd: #fff; box-shadow: var(--shadow-md); }

.sc-btn--ghost { --btn-bg: transparent; --btn-fg: var(--ink-800); --btn-bd: var(--ink-300); }
.sc-btn--ghost:hover { --btn-bg: var(--ink-800); --btn-fg: #fff; --btn-bd: var(--ink-800); }

.sc-btn--text {
  --btn-bg: transparent; --btn-fg: var(--green-600); --btn-bd: transparent;
  padding: 8px 4px;
  border-radius: var(--radius-xs);
}
.sc-btn--text:hover {
  --btn-fg: var(--green-700-solid);
  transform: none;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.sc-btn--sm { padding: 9px 16px; font-size: .8125rem; }
.sc-btn--sm .sc-icon { width: 15px; height: 15px; }
.sc-btn--lg { padding: 18px 34px; font-size: 1.0625rem; }
.sc-btn--block { display: flex; width: 100%; }

.sc-btn[disabled],
.sc-btn--disabled {
  opacity: .5;
  pointer-events: none;
  transform: none;
  box-shadow: none;
}

/* ---- Puente con el botón de Elementor -----------------------------------
   Hace que el widget Button (con su clase .elementor-button) adopte la forma
   de marca. Si en un botón concreto quieres el estilo Elementor nativo,
   simplemente NO le añadas las clases sc-btn--* (este bloque solo da forma
   base; el color de variante lo aportas con clases sc-btn--primary, etc.).
-------------------------------------------------------------------------- */
.elementor-button {
  border-radius: var(--radius-pill);
  font-weight: var(--fw-bold);
  letter-spacing: .01em;
  transition: transform var(--t-fast), box-shadow var(--t-base), background var(--t-base);
}
.elementor-button:hover { transform: translateY(-2px); }
.elementor-button.elementor-size-sm { padding: 9px 16px; }
.elementor-button.elementor-size-md { padding: 12px 22px; }
.elementor-button.elementor-size-lg { padding: 18px 34px; }
/* Variantes de marca aplicables a un widget Button vía "CSS Classes" */
.elementor-button.sc-btn--primary   { background: var(--green-500); color: #fff; }
.elementor-button.sc-btn--primary:hover { background: var(--green-600); }
.elementor-button.sc-btn--secondary  { background: var(--red-500); color: #fff; }
.elementor-button.sc-btn--secondary:hover { background: var(--red-600); }
.elementor-button.sc-btn--dark       { background: var(--ink-800); color: var(--cream-50); }
.elementor-button.sc-btn--light      { background: var(--cream-50); color: var(--ink-800); }


/* ==========================================================================
   2. CARDS
   ========================================================================== */
.sc-card {
  background: var(--bg-surface);
  border: var(--border-width) solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}
.sc-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--border-default); }
.sc-card__title { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: 1.3rem; margin-bottom: var(--space-2); }
.sc-card__text  { color: var(--text-secondary); font-size: var(--fs-body); }
.sc-card__body  { /* contenedor genérico de cuerpo en variantes editoriales */ }

/* Editorial (imagen arriba) */
.sc-card--editorial { padding: 0; overflow: hidden; }
.sc-card--editorial .sc-card__body { padding: var(--space-6) var(--space-6) var(--space-8); }
.sc-card--editorial .sc-card__meta {
  font-size: var(--fs-label);
  font-weight: var(--fw-bold);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--red-500);
  margin-bottom: var(--space-2);
}

/* Beneficio (icono + texto) */
.sc-card--benefit { text-align: left; }
.sc-card--benefit .sc-card__icon {
  width: 54px; height: 54px;
  border-radius: var(--radius-md);
  display: grid; place-items: center;
  background: var(--green-100);
  color: var(--green-600);
  margin-bottom: var(--space-5);
}
.sc-card--benefit .sc-card__icon .sc-icon { width: 26px; height: 26px; }

/* Oscura */
.sc-card--dark {
  background: var(--ink-800);
  border-color: var(--border-inverse);
  color: var(--text-inverse);
  box-shadow: var(--shadow-lg);
}
.sc-card--dark .sc-card__title { color: #fff; }
.sc-card--dark .sc-card__text  { color: var(--text-inverse-muted); }
.sc-card--dark .sc-card__icon  { background: rgba(255,255,255,.08); color: var(--gold-soft); }
.sc-card--dark:hover { border-color: rgba(255,255,255,.22); }

/* Imagen completa con overlay */
.sc-card--image { padding: 0; overflow: hidden; position: relative; }
.sc-card--image img { width: 100%; aspect-ratio: 3/4; object-fit: cover; display: block; }
.sc-card--image .sc-card__overlay {
  position: absolute; inset: auto 0 0 0;
  padding: var(--space-6);
  background: linear-gradient(to top, rgba(20,20,20,.85), transparent);
  color: #fff;
}

/* Categoría */
.sc-card--category { padding: 0; overflow: hidden; display: block; text-align: center; }
.sc-card--category img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; }
.sc-card--category .sc-card__cat {
  padding: var(--space-5);
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 1.1rem;
}
.sc-card--category .sc-card__cat span {
  display: block;
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: .8125rem;
  color: var(--text-muted);
}

/* Testimonio */
.sc-card--testimonial { display: flex; flex-direction: column; gap: var(--space-5); }
.sc-card--testimonial .sc-card__quote {
  font-family: var(--font-display);
  font-size: 1.15rem; line-height: 1.5;
  color: var(--text-primary);
  font-weight: var(--fw-medium);
}
.sc-card--testimonial .sc-card__stars { color: var(--amber-500); display: flex; gap: 2px; }
.sc-card--testimonial .sc-card__author { display: flex; align-items: center; gap: var(--space-3); margin-top: auto; }
.sc-card--testimonial .sc-card__avatar {
  width: 44px; height: 44px;
  border-radius: var(--radius-pill);
  background: linear-gradient(135deg, var(--green-300), var(--green-500));
  flex: none;
  object-fit: cover;
}
.sc-card--testimonial .sc-card__author b { display: block; font-family: var(--font-display); font-weight: var(--fw-bold); }
.sc-card--testimonial .sc-card__author small { color: var(--text-muted); }


/* ==========================================================================
   3. PRODUCT CARD (salsa)
   --------------------------------------------------------------------------
   Markup propio (para sliders/destacados con HTML Widget) y, más abajo en
   woocommerce.css, las equivalencias para la card nativa de WooCommerce.
   ========================================================================== */
.sc-product-card {
  position: relative;
  background: var(--bg-surface);
  border: var(--border-width) solid var(--border-subtle);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}
.sc-product-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: var(--border-default); }

.sc-product-card__media {
  position: relative;
  aspect-ratio: 1;
  background: linear-gradient(150deg, var(--cream-100), var(--ink-100));
  display: grid; place-items: center;
  overflow: hidden;
}
.sc-product-card__media img { position: relative; z-index: 1; width: 100%; height: 100%; object-fit: cover; }
/* Halo orgánico tras el bote */
.sc-product-card__media::before {
  content: "";
  position: absolute;
  width: 70%; aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, var(--red-100), transparent 70%);
  opacity: .7;
}

.sc-product-card__badges {
  position: absolute; top: var(--space-3); left: var(--space-3);
  display: flex; flex-direction: column; gap: 6px; z-index: 2;
}
.sc-product-card__fav {
  position: absolute; top: var(--space-3); right: var(--space-3); z-index: 2;
  width: 38px; height: 38px;
  border-radius: var(--radius-pill);
  background: rgba(255,255,255,.9);
  display: grid; place-items: center;
  color: var(--ink-500);
  box-shadow: var(--shadow-xs);
  transition: color var(--t-fast), background var(--t-fast);
}
.sc-product-card__fav:hover { color: var(--red-500); background: #fff; }

.sc-product-card__body { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-3); flex: 1; }
.sc-product-card__head { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-3); }
.sc-product-card__desc { font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.5; }
.sc-product-card__foot { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); margin-top: auto; padding-top: var(--space-2); }

/* Destacada */
.sc-product-card--featured { border-color: var(--green-300); box-shadow: var(--shadow-md); }
.sc-product-card--featured .sc-product-card__media { background: linear-gradient(150deg, var(--green-100), var(--cream-100)); }
.sc-product-card--featured .sc-product-card__media::before { background: radial-gradient(circle, var(--green-200), transparent 70%); }

/* Compacta (carruseles) */
.sc-product-card--compact .sc-product-card__body { padding: var(--space-4); gap: var(--space-2); }
.sc-product-card--compact .sc-product-card__desc { display: none; }
.sc-product-card--compact .sc-product-card__media { aspect-ratio: 4/3; }


/* ==========================================================================
   4. BADGES & TAGS
   ========================================================================== */
.sc-badge {
  display: inline-flex; align-items: center; gap: .4em;
  font-size: var(--fs-label); font-weight: var(--fw-bold); line-height: 1;
  letter-spacing: .01em;
  padding: 6px 11px;
  border-radius: var(--radius-pill);
  background: var(--ink-100);
  color: var(--ink-700);
}
.sc-badge .sc-icon { width: 13px; height: 13px; }

.sc-badge--award      { background: linear-gradient(135deg, var(--gold), var(--amber-600)); color: #fff; box-shadow: 0 2px 8px -2px rgba(201,150,46,.6); }
.sc-badge--bestseller { background: var(--ink-800); color: #fff; }
.sc-badge--new        { background: var(--green-500); color: #fff; }
.sc-badge--nopreserv  { background: var(--green-100); color: var(--green-700-solid); }
.sc-badge--natural    { background: var(--amber-100); color: var(--amber-700); }
.sc-badge--soft       { background: var(--spice-1); color: #fff; }
.sc-badge--medium     { background: var(--spice-3); color: var(--ink-900); }
.sc-badge--hot        { background: var(--spice-5); color: #fff; }
.sc-badge--extreme    { background: var(--spice-7); color: #fff; }
.sc-badge--outline    { background: transparent; border: 1.5px solid var(--border-strong); color: var(--text-secondary); }


/* ==========================================================================
   5. ESCALA DE PICANTE (1 → 7)
   ========================================================================== */

/* Mini (para product card): chiles rellenos según nivel */
.sc-spice-mini { display: inline-flex; align-items: center; gap: 5px; }
.sc-spice-mini__chiles { display: inline-flex; gap: 2px; color: var(--spice-track); }
.sc-spice-mini__chiles .sc-chile { width: 15px; height: 15px; }
.sc-spice-mini__label { font-size: var(--fs-label); font-weight: var(--fw-bold); color: var(--text-secondary); }

/* Escala horizontal completa */
.sc-spice-scale { display: flex; flex-direction: column; gap: var(--space-3); }
.sc-spice-scale__track { display: flex; gap: 6px; }
.sc-spice-scale__seg {
  flex: 1; height: 14px;
  border-radius: var(--radius-xs);
  background: var(--spice-track);
  position: relative;
  transition: transform var(--t-fast);
}
.sc-spice-scale__seg[data-level="1"] { background: var(--spice-1); }
.sc-spice-scale__seg[data-level="2"] { background: var(--spice-2); }
.sc-spice-scale__seg[data-level="3"] { background: var(--spice-3); }
.sc-spice-scale__seg[data-level="4"] { background: var(--spice-4); }
.sc-spice-scale__seg[data-level="5"] { background: var(--spice-5); }
.sc-spice-scale__seg[data-level="6"] { background: var(--spice-6); }
.sc-spice-scale__seg[data-level="7"] { background: var(--spice-7); }
.sc-spice-scale__labels {
  display: flex; justify-content: space-between;
  font-size: var(--fs-label); font-weight: var(--fw-semibold); color: var(--text-muted);
}

/* Tag individual de nivel */
.sc-spice-tag {
  display: inline-flex; align-items: center; gap: .45em;
  font-size: var(--fs-label); font-weight: var(--fw-bold); line-height: 1;
  padding: 7px 12px;
  border-radius: var(--radius-pill);
  color: #fff;
}
.sc-spice-tag .sc-num { font-family: var(--font-display); }
.sc-spice-tag[data-level="1"] { background: var(--spice-1); }
.sc-spice-tag[data-level="2"] { background: var(--spice-2); color: var(--ink-900); }
.sc-spice-tag[data-level="3"] { background: var(--spice-3); color: var(--ink-900); }
.sc-spice-tag[data-level="4"] { background: var(--spice-4); }
.sc-spice-tag[data-level="5"] { background: var(--spice-5); }
.sc-spice-tag[data-level="6"] { background: var(--spice-6); }
.sc-spice-tag[data-level="7"] { background: var(--spice-7); }

/* Leyenda informativa */
.sc-spice-legend { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: var(--space-4); }
.sc-spice-legend__item {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
}
.sc-spice-legend__dot { width: 28px; height: 28px; border-radius: var(--radius-sm); flex: none; }
.sc-spice-legend__item b { font-family: var(--font-display); display: block; }
.sc-spice-legend__item small { color: var(--text-muted); }


/* ==========================================================================
   6. FORMULARIOS
   ========================================================================== */
.sc-form-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--space-5); }
.sc-form-label { font-size: var(--fs-label); font-weight: var(--fw-bold); color: var(--text-primary); }
.sc-form-label .sc-req { color: var(--red-500); }

.sc-form-control {
  font-size: var(--fs-body);
  padding: 13px 15px;
  border-radius: var(--radius-md);
  background: var(--white);
  border: 1.5px solid var(--border-default);
  color: var(--text-primary);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  width: 100%;
}
.sc-form-control::placeholder { color: var(--ink-300); }
.sc-form-control:hover { border-color: var(--border-strong); }
.sc-form-control:focus { outline: none; border-color: var(--green-500); box-shadow: var(--shadow-focus); }
textarea.sc-form-control { resize: vertical; min-height: 120px; }
select.sc-form-control {
  appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2355504A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 42px;
}
.sc-form-help { font-size: var(--fs-label); color: var(--text-muted); }

.sc-form-field--error .sc-form-control { border-color: var(--error); }
.sc-form-field--error .sc-form-help    { color: var(--error); }
.sc-form-field--success .sc-form-control { border-color: var(--success); }
.sc-form-field--success .sc-form-help    { color: var(--success); }
.sc-form-control[disabled] { background: var(--gray-50); color: var(--ink-300); cursor: not-allowed; border-color: var(--border-subtle); }

/* Checkbox & radio custom */
.sc-form-check { display: flex; align-items: flex-start; gap: 10px; font-size: var(--fs-body); cursor: pointer; margin-bottom: var(--space-3); }
.sc-form-check input { position: absolute; opacity: 0; width: 0; height: 0; }
.sc-form-check__box {
  width: 22px; height: 22px; flex: none;
  border: 1.5px solid var(--border-strong);
  border-radius: var(--radius-xs);
  background: #fff;
  display: grid; place-items: center;
  transition: all var(--t-fast);
  margin-top: 1px;
}
.sc-form-check--radio .sc-form-check__box { border-radius: var(--radius-pill); }
.sc-form-check__box svg { width: 14px; height: 14px; stroke: #fff; stroke-width: 3; fill: none; opacity: 0; transition: opacity var(--t-fast); }
.sc-form-check input:checked + .sc-form-check__box { background: var(--green-500); border-color: var(--green-500); }
.sc-form-check input:checked + .sc-form-check__box svg { opacity: 1; }
.sc-form-check--radio input:checked + .sc-form-check__box { background: var(--green-500); }
.sc-form-check--radio .sc-form-check__box svg { display: none; }
.sc-form-check--radio input:checked + .sc-form-check__box::after { content: ""; width: 8px; height: 8px; border-radius: 50%; background: #fff; }
.sc-form-check input:focus-visible + .sc-form-check__box { box-shadow: var(--shadow-focus); }


/* ==========================================================================
   7. HEADER / NAV
   --------------------------------------------------------------------------
   El header real se construirá con Elementor Theme Builder. Estas clases
   sirven para HTML Widgets, plantillas custom o para envolver el header.
   ========================================================================== */
.sc-promo-bar {
  background: var(--red-500); color: #fff;
  text-align: center;
  font-size: var(--fs-label); font-weight: var(--fw-semibold);
  padding: 9px 16px; letter-spacing: .02em;
}
.sc-promo-bar .sc-icon { width: 14px; height: 14px; vertical-align: -2px; }

.sc-site-header {
  background: var(--cream-50);
  border-bottom: 1px solid var(--border-subtle);
  position: relative;
  z-index: var(--z-header);
}
.sc-site-header--sticky { position: sticky; top: 0; box-shadow: var(--shadow-sm); }
.sc-site-header__inner { display: flex; align-items: center; gap: var(--space-8); height: 74px; }

.sc-site-logo { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: var(--fw-extra); font-size: 1.25rem; letter-spacing: -.02em; }
.sc-site-logo__mark { width: 38px; height: 38px; border-radius: var(--radius-sm); background: var(--green-500); display: grid; place-items: center; color: #fff; flex: none; }
.sc-site-logo small { display: block; font-family: var(--font-body); font-weight: var(--fw-semibold); font-size: .6rem; letter-spacing: .22em; text-transform: uppercase; color: var(--red-500); line-height: 1; margin-top: 2px; }

.sc-site-nav { display: flex; align-items: center; gap: var(--space-6); margin-right: auto; }
.sc-header__actions { display: flex; align-items: center; gap: var(--space-3); }

.sc-icon-btn {
  width: 42px; height: 42px;
  border-radius: var(--radius-pill);
  display: grid; place-items: center;
  color: var(--ink-700);
  transition: background var(--t-fast), color var(--t-fast);
  position: relative;
}
.sc-icon-btn:hover { background: var(--ink-100); color: var(--ink-900); }
.sc-icon-btn__count {
  position: absolute; top: 4px; right: 4px;
  min-width: 17px; height: 17px; padding: 0 4px;
  border-radius: var(--radius-pill);
  background: var(--red-500); color: #fff;
  font-size: 10px; font-weight: var(--fw-bold);
  display: grid; place-items: center;
}

.sc-hamburger { display: none; flex-direction: column; gap: 5px; width: 44px; height: 44px; align-items: center; justify-content: center; }
.sc-hamburger span { width: 22px; height: 2px; background: var(--ink-800); border-radius: 2px; }


/* ==========================================================================
   8. FOOTER
   --------------------------------------------------------------------------
   El footer real se construirá con Elementor Theme Builder.
   ========================================================================== */
.sc-site-footer { background: var(--ink-900); color: var(--text-inverse-muted); padding-top: var(--space-20); }
.sc-site-footer a { color: var(--text-inverse-muted); transition: color var(--t-fast); }
.sc-site-footer a:hover { color: #fff; }

.sc-footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.4fr; gap: var(--space-10); padding-bottom: var(--space-16); }
.sc-footer__brand .sc-site-logo { color: #fff; }
.sc-footer__title { font-family: var(--font-display); font-weight: var(--fw-bold); color: #fff; font-size: 1rem; margin-bottom: var(--space-4); letter-spacing: .02em; }
.sc-footer__links { display: flex; flex-direction: column; gap: var(--space-3); font-size: var(--fs-small); }
.sc-footer__social { display: flex; gap: 10px; margin-top: var(--space-5); }
.sc-footer__social a { width: 38px; height: 38px; border-radius: var(--radius-pill); border: 1px solid var(--border-inverse); display: grid; place-items: center; }
.sc-footer__social a:hover { background: var(--green-500); border-color: var(--green-500); color: #fff; }
.sc-footer__pay { display: flex; gap: 8px; flex-wrap: wrap; margin-top: var(--space-4); }
.sc-footer__pay span { padding: 5px 10px; border: 1px solid var(--border-inverse); border-radius: var(--radius-sm); font-size: 11px; font-weight: var(--fw-bold); letter-spacing: .04em; color: #fff; }
.sc-footer__bottom { border-top: 1px solid var(--border-inverse); padding: var(--space-6) 0; display: flex; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap; font-size: var(--fs-label); }
.sc-footer__newsletter { display: flex; gap: 8px; }
.sc-footer__newsletter .sc-form-control { background: rgba(255,255,255,.06); border-color: var(--border-inverse); color: #fff; }
.sc-footer__newsletter .sc-form-control::placeholder { color: #8d887f; }


/* ==========================================================================
   9. HERO
   ========================================================================== */
.sc-hero { position: relative; overflow: hidden; background: var(--ink-900); color: #fff; border-radius: var(--radius-xl); }
.sc-hero__bg { position: absolute; inset: 0; background: linear-gradient(115deg, var(--ink-900) 38%, rgba(20,20,20,.35)), linear-gradient(135deg, var(--cream-100), var(--ink-200)); }
.sc-hero__inner { position: relative; z-index: 2; padding: clamp(40px, 6vw, 80px); max-width: 620px; }
.sc-hero__pills { display: flex; gap: 8px; flex-wrap: wrap; margin-top: var(--space-6); }
.sc-hero__pill { display: inline-flex; align-items: center; gap: 6px; font-size: var(--fs-label); font-weight: var(--fw-bold); padding: 7px 13px; border-radius: var(--radius-pill); background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18); }
.sc-hero__pill .sc-icon { width: 15px; height: 15px; color: var(--green-300); }
.sc-hero__cta { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-top: var(--space-8); }
.sc-hero__medal { position: absolute; right: clamp(24px, 5vw, 72px); bottom: clamp(24px, 5vw, 56px); z-index: 2; }

/* Medalla de premio */
.sc-medal {
  width: 108px; height: 108px;
  border-radius: 50%;
  display: grid; place-items: center; text-align: center;
  background: radial-gradient(circle at 30% 25%, var(--gold-soft), var(--amber-600));
  color: var(--ink-900);
  box-shadow: 0 12px 30px -8px rgba(0,0,0,.5), inset 0 0 0 4px rgba(255,255,255,.35);
  font-family: var(--font-display);
}
.sc-medal b { font-size: 1.5rem; line-height: 1; }
.sc-medal small { font-size: .55rem; font-weight: var(--fw-bold); letter-spacing: .1em; text-transform: uppercase; }


/* ==========================================================================
   10. BENEFITS & FAQ
   ========================================================================== */
.sc-benefit-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-6); }
.sc-benefit { text-align: center; }
.sc-benefit__icon {
  width: 72px; height: 72px;
  margin: 0 auto var(--space-4);
  border-radius: var(--radius-pill);
  display: grid; place-items: center;
  background: var(--white);
  border: 1px solid var(--border-subtle);
  color: var(--green-600);
  box-shadow: var(--shadow-sm);
}
.sc-benefit__icon .sc-icon { width: 30px; height: 30px; }
.sc-section--dark .sc-benefit__icon { background: rgba(255,255,255,.06); border-color: var(--border-inverse); color: var(--gold-soft); }

.sc-faq-item { border-bottom: 1px solid var(--border-default); }
.sc-faq-item summary {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
  padding: var(--space-5) 0; cursor: pointer;
  font-family: var(--font-display); font-weight: var(--fw-bold); font-size: 1.1rem;
  list-style: none;
}
.sc-faq-item summary::-webkit-details-marker { display: none; }
.sc-faq-item summary .sc-icon { color: var(--green-600); transition: transform var(--t-base); flex: none; }
.sc-faq-item[open] summary .sc-icon { transform: rotate(45deg); }
.sc-faq-item p { padding-bottom: var(--space-5); color: var(--text-secondary); max-width: 62ch; }


/* ==========================================================================
   RESPONSIVE (componentes)
   ========================================================================== */
@media (max-width:1024px){
  .sc-footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-10); }
}
@media (max-width:768px){
  .sc-site-nav { display: none; }
  .sc-hamburger { display: flex; }
  .sc-header__actions .sc-btn { display: none; }
  .sc-hero__medal { right: 18px; bottom: 18px; }
  .sc-medal { width: 86px; height: 86px; }
}
@media (max-width:560px){
  .sc-footer__grid { grid-template-columns: 1fr; }
  .sc-btn--lg { padding: 15px 26px; }
  .sc-footer__newsletter { flex-direction: column; }
}
