/* ============================================================
   Complete Aesthete — Component styles
   ------------------------------------------------------------
   Class-based styles for the React primitives in /components.
   Everything is driven by SEMANTIC tokens (--accent*, --text*,
   --surface*) so any subtree wrapped in .theme-pink / .theme-sage
   / .theme-gold re-skins automatically.
   ============================================================ */

/* ---------- Button ---------- */
.ca-btn {
  font-family: var(--font-sans);
  font-weight: var(--w-bold);
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  padding: 14px 28px;
  border-radius: var(--radius-sm);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: var(--transition);
  line-height: 1; white-space: nowrap;
  text-decoration: none;
}
.ca-btn:focus-visible { outline: none; box-shadow: var(--ring); }
.ca-btn--primary { background: var(--accent); color: var(--text-onAccent); }
.ca-btn--primary:hover { background: var(--accent-deep); transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.ca-btn--secondary { background: transparent; color: var(--accent); border-color: var(--accent); }
.ca-btn--secondary:hover { background: var(--accent-wash); }
.ca-btn--ghost { background: transparent; color: var(--accent); }
.ca-btn--ghost:hover { background: var(--accent-wash); }
.ca-btn--soft { background: var(--accent-wash); color: var(--accent-deep); }
.ca-btn--soft:hover { background: var(--accent-tint); }
.ca-btn--sm { padding: 10px 18px; font-size: 11px; }
.ca-btn--lg { padding: 17px 36px; font-size: 14px; letter-spacing: 0.16em; }
.ca-btn--block { width: 100%; }
.ca-btn:disabled, .ca-btn[aria-disabled="true"] { opacity: 0.45; pointer-events: none; }
.ca-btn svg { width: 1.15em; height: 1.15em; stroke-width: 1.6; }

/* ---------- IconButton ---------- */
.ca-iconbtn {
  display: inline-grid; place-items: center;
  width: 42px; height: 42px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border-soft);
  background: var(--paper); color: var(--text-muted);
  cursor: pointer; transition: var(--transition);
}
.ca-iconbtn:hover { color: var(--accent); border-color: var(--border-accent); background: var(--accent-wash); }
.ca-iconbtn:focus-visible { outline: none; box-shadow: var(--ring); }
.ca-iconbtn--ghost { border-color: transparent; background: transparent; }
.ca-iconbtn--sm { width: 34px; height: 34px; }
.ca-iconbtn svg { width: 19px; height: 19px; stroke-width: 1.5; }

/* ---------- Tag ---------- */
.ca-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-sans); font-weight: var(--w-bold);
  font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase;
  padding: 6px 12px; border-radius: var(--radius-pill);
  background: var(--accent-wash); color: var(--accent-deep);
}
.ca-tag--solid { background: var(--accent); color: var(--text-onAccent); }
.ca-tag--outline { background: transparent; color: var(--accent); border: 1px solid var(--border-accent); }
.ca-tag--quiet { background: var(--surface-sunken); color: var(--text-muted); }

/* ---------- Badge (count / label) ---------- */
.ca-badge {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-sans); font-weight: var(--w-bold);
  font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase;
  min-width: 20px; padding: 3px 8px; border-radius: var(--radius-pill);
  background: var(--accent); color: var(--text-onAccent);
}
.ca-badge--new { background: var(--accent-deep); }
.ca-badge--sale { background: var(--error); }
.ca-badge--soft { background: var(--accent-tint); color: var(--accent-deep); }

/* ---------- Medallion (the "36 TEMPLATES" circle) ---------- */
.ca-medallion {
  display: inline-flex; flex-direction: column; align-items: center; justify-content: center;
  width: 92px; height: 92px; border-radius: var(--radius-pill);
  background: var(--accent); color: var(--text-onAccent); text-align: center;
  box-shadow: var(--shadow-sm);
}
.ca-medallion__num { font-family: var(--font-serif); font-weight: 500; font-size: 34px; line-height: 0.9; }
.ca-medallion__label { font-family: var(--font-sans); font-weight: var(--w-bold); font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase; margin-top: 3px; opacity: 0.92; }

/* ---------- Colorway swatches ---------- */
.ca-colorways { display: inline-flex; align-items: center; gap: 12px; }
.ca-swatch {
  width: 26px; height: 26px; border-radius: var(--radius-pill);
  border: 2px solid transparent; padding: 0; cursor: pointer;
  position: relative; transition: var(--transition);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.06);
}
.ca-swatch:hover { transform: scale(1.08); }
.ca-swatch[aria-pressed="true"] { border-color: var(--ink); }
.ca-swatch:focus-visible { outline: none; box-shadow: var(--ring); }
.ca-colorways__label { font-family: var(--font-sans); font-size: 12px; color: var(--text-muted); letter-spacing: 0.04em; }

/* ---------- Ribbon divider ---------- */
.ca-ribbon { display: flex; align-items: center; gap: 18px; width: 100%; }
.ca-ribbon::before, .ca-ribbon::after { content: ""; flex: 1; height: 1px; background: var(--border-accent); }
.ca-ribbon img { height: 34px; width: auto; }
.ca-ribbon--sm img { height: 26px; }

/* ---------- Input / Field ---------- */
.ca-field { display: flex; flex-direction: column; gap: 7px; }
.ca-label { font-family: var(--font-sans); font-weight: var(--w-bold); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-muted); }
.ca-input {
  font-family: var(--font-sans); font-size: 15px; color: var(--text-strong);
  padding: 12px 14px; border: 1px solid var(--border-soft);
  border-radius: var(--radius-sm); background: var(--paper);
  transition: var(--transition); width: 100%;
}
.ca-input::placeholder { color: var(--mute); }
.ca-input:focus { outline: none; border-color: var(--accent); box-shadow: var(--ring); }
.ca-input--line {
  border: none; border-bottom: 1.5px solid var(--border-accent);
  border-radius: 0; padding: 8px 2px; background: transparent;
}
.ca-input--line:focus { box-shadow: none; border-bottom-color: var(--accent); }
.ca-field__hint { font-family: var(--font-sans); font-size: 12px; color: var(--text-muted); }

/* ---------- Checkbox ---------- */
.ca-check { display: inline-flex; align-items: center; gap: 10px; cursor: pointer; font-family: var(--font-sans); font-size: 14px; color: var(--text-body); }
.ca-check input { position: absolute; opacity: 0; width: 0; height: 0; }
.ca-check__box {
  width: 20px; height: 20px; flex: none; border-radius: var(--radius-xs);
  border: 1.5px solid var(--border-accent); background: var(--paper);
  display: grid; place-items: center; transition: var(--transition);
}
.ca-check__box svg { width: 13px; height: 13px; stroke: var(--text-onAccent); stroke-width: 3; opacity: 0; transition: var(--transition); }
.ca-check input:checked + .ca-check__box { background: var(--accent); border-color: var(--accent); }
.ca-check input:checked + .ca-check__box svg { opacity: 1; }
.ca-check input:focus-visible + .ca-check__box { box-shadow: var(--ring); }

/* ---------- Price ---------- */
.ca-price { display: inline-flex; align-items: baseline; gap: 10px; font-family: var(--font-sans); }
.ca-price__now { font-weight: var(--w-bold); font-size: 18px; color: var(--text-strong); }
.ca-price__was { font-size: 14px; color: var(--text-muted); text-decoration: line-through; }
.ca-price__save { font-size: 10.5px; font-weight: var(--w-bold); letter-spacing: 0.08em; text-transform: uppercase; color: var(--error); }
.ca-price--lg .ca-price__now { font-size: 24px; }

/* ---------- Product card ---------- */
.ca-product {
  display: flex; flex-direction: column;
  background: var(--surface-card); border: 1px solid var(--border-soft);
  border-radius: var(--radius-md); overflow: hidden; transition: var(--transition);
  text-decoration: none; color: inherit;
}
.ca-product:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--border-accent); }
.ca-product__media { position: relative; aspect-ratio: 4 / 5; background: var(--surface-sunken); overflow: hidden; }
.ca-product__media img { width: 100%; height: 100%; object-fit: cover; }
.ca-product__flags { position: absolute; top: 12px; left: 12px; display: flex; gap: 6px; }
.ca-product__fav { position: absolute; top: 10px; right: 10px; }
.ca-product__body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 9px; }
.ca-product__eyebrow { font-family: var(--font-sans); font-weight: var(--w-bold); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); }
.ca-product__title { font-family: var(--font-serif); font-size: 19px; font-weight: 500; letter-spacing: 0.02em; color: var(--text-strong); line-height: 1.2; }
.ca-product__row { display: flex; align-items: center; justify-content: space-between; margin-top: 2px; }
