/* ============================================================
   TOMAS EXTENSIONS — COMPONENT STYLES
   Pure CSS classes; no framework. Pair with tokens.css.
   ============================================================ */

/* ─────────────  TYPOGRAPHY  ───────────── */
.t-eyebrow {
  font-family: var(--font-sans);
  font-size: var(--t-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: var(--tr-widest);
  color: var(--fg-muted);
}
.t-mono {
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  letter-spacing: 0;
}

.h-display {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(64px, 11vw, var(--t-5xl));
  line-height: var(--lh-tight);
  letter-spacing: var(--tr-tight);
  margin: 0;
}
.h-1 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--t-4xl);
  line-height: var(--lh-tight);
  letter-spacing: var(--tr-tight);
  margin: 0;
}
.h-2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--t-3xl);
  line-height: var(--lh-snug);
  letter-spacing: var(--tr-snug);
  margin: 0;
}
.h-3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--t-2xl);
  line-height: var(--lh-snug);
  letter-spacing: var(--tr-snug);
  margin: 0;
}
.h-4 {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--t-xl);
  line-height: var(--lh-snug);
  letter-spacing: var(--tr-snug);
  margin: 0;
}
.italic-accent { font-style: italic; }
.muted { color: var(--fg-muted); }
.faint { color: var(--fg-faint); }

/* ─────────────  BUTTONS  ───────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 0;
  cursor: pointer;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: var(--t-sm);
  letter-spacing: 0.01em;
  padding: 14px 22px;
  border-radius: var(--r-pill);
  transition: color var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
  text-decoration: none;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn .arrow {
  display: inline-flex;
  width: 22px; height: 22px;
  border-radius: 999px;
  background-color: rgba(255,255,255,0.18);
  align-items: center; justify-content: center;
}
.btn--primary {
  background-color: var(--action-1-bg);
  color: var(--action-1-fg);
}
.btn--primary:hover { background-color: var(--action-1-hover); }
.btn--secondary {
  background-color: var(--action-2-bg);
  color: var(--action-2-fg);
}
.btn--secondary:hover { background-color: var(--action-2-hover); }
.btn--ghost {
  background-color: var(--action-ghost-bg);
  color: var(--action-ghost-fg);
  border: 1px solid var(--action-ghost-line);
}
.btn--ghost:hover { background-color: var(--action-ghost-hover); }
.btn--icon {
  width: 44px; height: 44px;
  padding: 0;
  justify-content: center;
}
.btn--lg { padding: 18px 28px; font-size: var(--t-base); }
.btn--sm { padding: 10px 16px; font-size: var(--t-xs); }

/* ─────────────  TAGS / PILLS  ───────────── */
.tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  border: 1px solid var(--line-strong);
  color: var(--fg);
  background: transparent;
}
.tag--solid {
  background: var(--bg-inverse);
  color: var(--fg-inverse);
  border-color: transparent;
}
.tag--pink   { background: var(--pink-400); color: #1A0A12; border-color: transparent; }
.tag--amber  { background: var(--amber-400); color: #1A1505; border-color: transparent; }

/* ─────────────  CARDS  ───────────── */
.card {
  background: var(--bg-raised);
  border-radius: var(--r-xl);
  padding: var(--s-6);
  border: 1px solid var(--line);
}
.card--product {
  display: flex; flex-direction: column; gap: var(--s-4);
}
.card--image {
  padding: 0;
  overflow: hidden;
}
.card--image .card-body { padding: var(--s-4) var(--s-5); }
.card--accent-pink   { background: var(--pink-400); color: #1A0A12; }
.card--accent-amber  { background: var(--amber-400); color: #1A1505; }
.card--accent-dark   { background: #0F0F0F; color: #F5F1EA; }
.caption-pill {
  display: inline-block;
  padding: 8px 14px;
  background: var(--bg-raised);
  border-radius: var(--r-pill);
  font-size: var(--t-sm);
  font-weight: 500;
}

/* ─────────────  INPUTS  ───────────── */
.field { display: flex; flex-direction: column; gap: 6px; }
.field-label {
  font-family: var(--font-sans);
  font-size: var(--t-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--fg-muted);
  font-weight: 500;
}
.input, .select, .textarea {
  font-family: var(--font-sans);
  font-size: var(--t-base);
  color: var(--fg);
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--line-strong);
  padding: 12px 0;
  outline: 0;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.input:focus, .select:focus, .textarea:focus {
  border-color: var(--pink-400);
}
.input::placeholder, .textarea::placeholder { color: var(--fg-faint); }

.input--filled, .select--filled {
  background: var(--bg-raised);
  border: 1px solid var(--line);
  border-radius: var(--r-pill);
  padding: 14px 20px;
}
.input--filled:focus, .select--filled:focus { border-color: var(--pink-400); }
.textarea { resize: vertical; min-height: 96px; }

/* ─────────────  ACCORDION / FAQ  ───────────── */
.accordion-item {
  border-bottom: 1px solid var(--line);
  padding: var(--s-5) 0;
}
.accordion-trigger {
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: var(--t-md);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--fg);
  list-style: none;
}
.accordion-trigger::-webkit-details-marker { display: none; }
.accordion-num {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--fg-muted);
  margin-left: var(--s-3);
}
.accordion-body {
  margin-top: var(--s-3);
  color: var(--fg-muted);
  font-size: var(--t-base);
  max-width: 60ch;
}
details[open] .accordion-chev { transform: rotate(180deg); }
.accordion-chev { transition: transform var(--dur-base) var(--ease-out); }

/* ─────────────  IMAGE FRAME (with caption pill)  ───────────── */
.frame {
  position: relative;
  border-radius: var(--r-xl);
  overflow: hidden;
  background: var(--bg-sunken);
  display: block;
}
.frame img { display: block; width: 100%; height: 100%; object-fit: cover; }
.frame .caption-pill {
  position: absolute;
  left: var(--s-4); bottom: var(--s-4);
}
.frame .icon-pill {
  position: absolute;
  right: var(--s-4); top: var(--s-4);
  width: 36px; height: 36px;
  border-radius: 999px;
  background: var(--bg-raised);
  display: inline-flex; align-items: center; justify-content: center;
}

/* ─────────────  DECORATIVE GRID + CROSSHAIRS  ───────────── */
.crosshair-grid {
  position: relative;
}
.crosshair-grid::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, var(--line) 1px, transparent 1px),
    linear-gradient(to bottom, var(--line) 1px, transparent 1px);
  background-size: 25% 80px;
  pointer-events: none;
  mask: radial-gradient(circle, transparent 60%, black 60%);
}
.cross {
  position: absolute;
  width: 14px; height: 14px;
  color: var(--fg-faint);
}
.cross::before, .cross::after {
  content: ""; position: absolute;
  background: currentColor;
}
.cross::before { left: 50%; top: 0; bottom: 0; width: 1px; transform: translateX(-50%); }
.cross::after  { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-50%); }

/* ─────────────  NAV / HEADER  ───────────── */
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s-5) var(--s-8);
  font-size: var(--t-sm);
}
.nav-list { display: flex; gap: var(--s-6); list-style: none; padding: 0; margin: 0; }
.nav-list a { color: var(--fg); text-decoration: none; }
.nav-list a:hover { color: var(--pink-400); }
.brandmark {
  font-family: var(--font-display);
  font-size: var(--t-lg);
  letter-spacing: var(--tr-snug);
}

/* ─────────────  FOOTER  ───────────── */
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr repeat(4, 1fr);
  gap: var(--s-8);
  padding: var(--s-12) 0;
}
.footer-col h6 {
  margin: 0 0 var(--s-4);
  font-size: var(--t-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--fg-muted);
  font-weight: 500;
}
.footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--s-3); }
.footer-col a { color: var(--fg); text-decoration: none; font-size: var(--t-sm); }
.footer-col a:hover { color: var(--pink-400); }

/* ─────────────  COPYRIGHT MARK  ───────────── */
.copy-mark {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: var(--t-md);
  letter-spacing: var(--tr-snug);
}
.copy-mark::before { content: "©"; margin-right: 1px; }

/* ─────────────  AVATAR STACK  ───────────── */
.avatars { display: inline-flex; }
.avatars > * {
  width: 40px; height: 40px;
  border-radius: 999px;
  border: 2px solid var(--bg);
  background: var(--bg-raised);
  margin-left: -10px;
  background-size: cover;
  background-position: center;
}
.avatars > *:first-child { margin-left: 0; }

/* ─────────────  SWATCH (for the design system page) ───────────── */
.swatch {
  border-radius: var(--r-md);
  aspect-ratio: 4 / 3;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--s-3);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.swatch-name {
  position: absolute; top: var(--s-3); left: var(--s-3);
  font-family: var(--font-sans); font-size: var(--t-xs);
  letter-spacing: var(--tr-wider); text-transform: uppercase;
}
