/* ==========================================================================
   ZEN W/ JEN — COMPONENTS
   Buttons · Cards · Typography blocks · Forms
   Built on tokens.css. Button classes mirror ACSS (.btn--primary etc.) and
   are complete styles — no hybrid overrides layered on top.
   ========================================================================== */

/* --------------------------------------------------------------------------
   BUTTONS
   -------------------------------------------------------------------------- */
.btn {
  --btn-bg: var(--accent);
  --btn-bg-hover: var(--accent-hover);
  --btn-color: var(--heading-color);
  --btn-padding-block: 0.85em;
  --btn-padding-inline: 1.6em;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  font-family: var(--text-font-family);
  font-size: var(--text-m);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.01em;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  padding: var(--btn-padding-block) var(--btn-padding-inline);
  color: var(--btn-color);
  background-color: var(--btn-bg);
  border: 2px solid transparent;
  border-radius: var(--radius-round);
  transition: background-color var(--transition), color var(--transition),
              transform var(--transition), box-shadow var(--transition);
}
.btn:hover { background-color: var(--btn-bg-hover); transform: translateY(-2px); box-shadow: var(--shadow-m); }
.btn:active { transform: translateY(0); box-shadow: var(--shadow-s); }

/* Variants — each sets its own complete color pair */
.btn--accent    { --btn-bg: var(--accent);          --btn-bg-hover: var(--accent-hover);     --btn-color: var(--heading-color); }
.btn--primary   { --btn-bg: var(--primary);         --btn-bg-hover: var(--primary-hover);    --btn-color: var(--heading-color); }
.btn--secondary { --btn-bg: var(--secondary-dark);  --btn-bg-hover: var(--secondary-ultra-dark); --btn-color: var(--white); }
.btn--tertiary  { --btn-bg: var(--tertiary);        --btn-bg-hover: var(--tertiary-hover);    --btn-color: var(--heading-color); }

.btn--outline {
  background-color: transparent;
  border-color: var(--accent);
  color: var(--accent-dark);
}
.btn--outline:hover { background-color: var(--accent); color: var(--heading-color); transform: translateY(-2px); box-shadow: var(--shadow-m); }

.btn--ghost {
  background-color: transparent;
  color: var(--secondary-dark);
  padding-inline: 0.6em;
}
.btn--ghost:hover { background-color: var(--secondary-ultra-light); color: var(--secondary-ultra-dark); transform: none; box-shadow: none; }

/* Sizes */
.btn--s { font-size: var(--text-s); --btn-padding-block: 0.7em; --btn-padding-inline: 1.25em; }
.btn--l { font-size: var(--text-l); --btn-padding-block: 1em; --btn-padding-inline: 2em; }

.btn:disabled, .btn[aria-disabled="true"] {
  opacity: 0.5; cursor: not-allowed; transform: none; box-shadow: none;
}

/* --------------------------------------------------------------------------
   CARDS
   -------------------------------------------------------------------------- */
.card {
  display: flex;
  flex-direction: column;
  background-color: var(--white);
  border: var(--border);
  border-radius: var(--radius-l);
  overflow: hidden;
  box-shadow: var(--shadow-s);
  transition: transform var(--transition), box-shadow var(--transition);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-l); }

.card__media { aspect-ratio: 4 / 3; overflow: hidden; }
.card__media img { width: 100%; height: 100%; object-fit: cover; }

.card__body { display: flex; flex-direction: column; gap: var(--space-xs); padding: var(--space-m); }
.card__eyebrow { font-size: var(--eyebrow-size); font-weight: 600; letter-spacing: var(--eyebrow-letter-spacing); text-transform: uppercase; color: var(--accent-dark); }
.card__title { font-size: var(--h5); color: var(--heading-color); }
.card__text { font-size: var(--text-s); color: var(--text-muted); margin: 0; }
.card__footer { margin-top: auto; padding-top: var(--space-s); }

/* Soft tinted card (no photo) */
.card--soft { background-color: var(--primary-ultra-light); border-color: transparent; }
.card--soft.card--ocean   { background-color: var(--secondary-ultra-light); }
.card--soft.card--sun     { background-color: var(--tertiary-ultra-light); }
.card--soft.card--blossom { background-color: var(--blossom-ultra-light); }

/* Scrapbook "polaroid" photo card — slight tilt, white frame, tape */
.card--photo {
  background-color: var(--white);
  border: 0;
  border-radius: var(--radius-s);
  padding: var(--space-xs) var(--space-xs) var(--space-m);
  box-shadow: var(--shadow-photo);
  position: relative;
  rotate: -2deg;
}
.card--photo:nth-of-type(even) { rotate: 2deg; }
.card--photo:hover { rotate: 0deg; transform: translateY(-4px); }
.card--photo .card__media { aspect-ratio: 1; border-radius: var(--radius-s); }
.card--photo .card__caption {
  font-family: var(--script-font-family);
  font-size: var(--text-xl);
  color: var(--secondary-dark);
  text-align: center;
  padding-top: var(--space-xs);
}
/* Washi tape accent */
.card--photo::before {
  content: "";
  position: absolute;
  top: -0.6rem; left: 50%;
  width: 5.5rem; height: 1.6rem;
  translate: -50% 0;
  rotate: -4deg;
  background: color-mix(in oklab, var(--tertiary) 75%, transparent);
  box-shadow: var(--shadow-s);
}

/* --------------------------------------------------------------------------
   TYPOGRAPHY BLOCKS
   -------------------------------------------------------------------------- */
.stack { display: flex; flex-direction: column; gap: var(--space-s); max-width: var(--content-narrow); }
.stack--center { align-items: center; text-align: center; margin-inline: auto; }
.stack > * { margin: 0; }
.stack .script { font-size: var(--h3); }

.hero-title { font-size: var(--h1); }
.hero-title em { font-style: italic; color: var(--accent-dark); }

/* Oversized display beat — one per page */
.display-xl {
  font-family: var(--heading-font-family);
  font-weight: 600;
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--heading-color);
  font-size: clamp(3.5rem, 2rem + 8vw, 9rem);
}

.lede { font-size: var(--text-l); color: var(--text-muted); line-height: 1.6; }

/* --------------------------------------------------------------------------
   FORMS
   -------------------------------------------------------------------------- */
.field { display: flex; flex-direction: column; gap: 0.4rem; margin-bottom: var(--space-s); }
.field label { font-size: var(--text-s); font-weight: 600; color: var(--heading-color); }
.field .hint { font-size: var(--text-xs); color: var(--text-muted); }

.input, .textarea, .select {
  font-family: var(--text-font-family);
  font-size: var(--text-m);
  color: var(--text);
  background-color: var(--white);
  padding: 0.75em 1em;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius);
  transition: border-color var(--transition), box-shadow var(--transition);
  width: 100%;
}
.input::placeholder, .textarea::placeholder { color: color-mix(in oklab, var(--text-muted) 80%, transparent); }
.input:focus, .textarea:focus, .select:focus {
  outline: none;
  border-color: var(--secondary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--secondary) 25%, transparent);
}
.textarea { min-height: 7rem; resize: vertical; }
.select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--secondary-dark) 50%), linear-gradient(135deg, var(--secondary-dark) 50%, transparent 50%); background-position: calc(100% - 1.1rem) center, calc(100% - 0.75rem) center; background-size: 0.4rem 0.4rem, 0.4rem 0.4rem; background-repeat: no-repeat; padding-right: 2.5rem; }

/* Checkbox / radio */
.check { display: flex; align-items: center; gap: 0.6rem; font-size: var(--text-s); cursor: pointer; }
.check input { width: 1.15rem; height: 1.15rem; accent-color: var(--accent); }

/* Inline email signup — Jen's conversion element */
.signup {
  display: flex; gap: var(--space-xs); flex-wrap: wrap;
  background-color: var(--white);
  padding: var(--space-xs);
  border: var(--border);
  border-radius: var(--radius-round);
  box-shadow: var(--shadow-s);
  max-width: 32rem;
}
.signup .input { flex: 1 1 12rem; border: 0; border-radius: var(--radius-round); box-shadow: none; padding-inline: 1.25em; }
.signup .input:focus { box-shadow: none; }
.signup .btn { flex: 0 0 auto; }

/* Carded signup block */
.signup-card {
  background-color: var(--secondary-ultra-light);
  border-radius: var(--radius-l);
  padding: var(--space-l);
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: var(--space-s);
}
