/* components.css — buttons, cards, inputs, search, pills, hero, ads, related */

/* ---- buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-sm); font-weight: var(--w-semi); letter-spacing: -0.01em;
  padding: var(--s-3) var(--s-5); border-radius: var(--r-sm);
  border: 1px solid var(--c-hair-strong); background: var(--c-surface);
  box-shadow: var(--shadow-flat);
  transition: border-color var(--dur-2) var(--ease), transform var(--dur-1) var(--ease),
              background var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease);
}
.btn:hover { border-color: var(--c-ink); transform: translateY(-1px); box-shadow: var(--shadow-rest); color: var(--c-ink); }
.btn:active { transform: translateY(0); }
.btn--accent { background: var(--c-accent); color: #fff !important; border-color: var(--c-accent); }
.btn--accent:hover { background: var(--c-accent-deep); border-color: var(--c-accent-deep); color: #fff !important; }
.btn--ghost { background: transparent; border-color: transparent; box-shadow: none; padding-inline: var(--s-2); }
.btn--ghost:hover { background: var(--c-surface-sunk); border-color: transparent; box-shadow: none; transform: none; }

/* ---- hero ---- */
.hero { padding-block: var(--s-9) var(--s-7); position: relative;
  display: grid; grid-template-columns: minmax(0, 1fr) clamp(300px, 34%, 400px); gap: var(--s-8); align-items: center; }
.hero__copy { min-width: 0; }
.hero__title { font-size: var(--t-xxl); max-width: 15ch; letter-spacing: -0.035em; }
.hero__lede { margin-top: var(--s-5); font-size: var(--t-lg); color: var(--c-ink-soft); max-width: 52ch; font-weight: var(--w-reg); line-height: 1.5; }
.hero__meta { margin-top: var(--s-6); font-family: var(--f-mono); font-size: var(--t-sm); color: var(--c-ink-faint); letter-spacing: 0.01em; max-width: 60ch; }
.hero__meta b { color: var(--c-ink-soft); font-weight: var(--w-med); }

/* floating benchmark figure (Stripe-docs style, subtle) */
.hero__figure { position: relative; justify-self: end; width: 100%; max-width: 340px; animation-delay: 220ms; }
.hero__figure::before { content: ""; position: absolute; inset: -28px -28px auto auto; width: 150px; height: 110px;
  background-image: radial-gradient(var(--c-hair-strong) 1.1px, transparent 1.1px); background-size: 13px 13px; opacity: 0.6; z-index: -1; }
.hf-card { background: var(--c-surface); border: 1px solid var(--c-hair); border-radius: var(--r-lg); box-shadow: var(--shadow-pop); padding: var(--s-5); }
.hf-card__head { display: flex; align-items: center; justify-content: space-between; gap: var(--s-3); margin-bottom: var(--s-5); }
.hf-card__metric { font-family: var(--f-display); font-weight: var(--w-semi); font-size: var(--t-sm); letter-spacing: -0.01em; }
.hf-card__tag { font-family: var(--f-mono); font-size: var(--t-xs); color: var(--c-ink-faint); }
.hf-bars { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--s-4); height: 88px; }
.hf-bar { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: flex-end; gap: var(--s-2); height: 100%; }
.hf-bar__v { font-family: var(--f-mono); font-size: var(--t-xs); color: var(--c-ink-soft); }
.hf-bar__b { width: 100%; max-width: 40px; height: var(--h, 100%); border-radius: 5px 5px 0 0; background: var(--c-surface-sunk); border: 1px solid var(--c-hair-strong); }
.hf-bar__n { font-family: var(--f-mono); font-size: var(--t-xs); color: var(--c-ink-faint); }
.hf-bar--you .hf-bar__b { background: var(--c-accent); border-color: var(--c-accent); height: 54%; }
.hf-bar--you .hf-bar__v, .hf-bar--you .hf-bar__n { color: var(--c-accent); font-weight: var(--w-semi); }
.hf-bar--median .hf-bar__b { background: var(--c-ink-faint); border-color: var(--c-ink-faint); height: 76%; }
.hf-bar--top .hf-bar__b { height: 100%; }
.hf-chip { position: absolute; left: -22px; bottom: -78px; background: var(--c-note-wash); border: 1px solid var(--c-note-line);
  border-radius: var(--r-md); box-shadow: var(--shadow-lift); padding: var(--s-3) var(--s-4); display: grid; gap: 1px; transform: rotate(-3deg); }
.hf-chip__label { font-family: var(--f-mono); font-size: 0.625rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-note); }
.hf-chip__value { font-family: var(--f-mono); font-size: var(--t-lg); font-weight: var(--w-semi); letter-spacing: -0.02em; color: var(--c-ink); }
.hf-chip__note { font-family: var(--f-mono); font-size: var(--t-xs); color: var(--c-ink-faint); }

@media (max-width: 880px) {
  .hero { grid-template-columns: 1fr; }
  .hero__figure { display: none; }
}

/* ---- search (floating overlay) ---- */
.search { position: relative; margin-top: var(--s-6); max-width: 640px; z-index: 150; }
.search__field {
  width: 100%; background: var(--c-surface); border: 1px solid var(--c-hair-strong);
  border-radius: var(--r-md); padding: var(--s-4) var(--s-5) var(--s-4) calc(var(--s-5) + 24px);
  font-size: var(--t-md); box-shadow: var(--shadow-rest);
  transition: border-color var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease);
}
.search__field::placeholder { color: var(--c-ink-faint); }
.search__field:focus { outline: none; border-color: var(--c-accent); box-shadow: var(--shadow-lift), 0 0 0 4px var(--c-accent-wash); }
.search__icon { position: absolute; left: var(--s-4); top: 26px; transform: translateY(-50%); color: var(--c-ink-faint); pointer-events: none; }
.search__results {
  position: absolute; left: 0; right: 0; top: calc(100% + 8px); z-index: 160;
  background: var(--c-surface); border: 1px solid var(--c-hair-strong); border-radius: var(--r-md);
  box-shadow: var(--shadow-pop); overflow: hidden; padding: var(--s-2);
  max-height: 360px; overflow-y: auto; overscroll-behavior: contain;
  transform-origin: top center;
  animation: pop var(--dur-2) var(--ease-out);
}
.search__results[hidden] { display: none; }
@keyframes pop { from { opacity: 0; transform: translateY(-6px) scale(0.99); } to { opacity: 1; transform: none; } }
.search__hit { display: flex; align-items: center; justify-content: space-between; gap: var(--s-3);
  padding: var(--s-3) var(--s-4); border-radius: var(--r-sm); }
.search__hit b { font-weight: var(--w-med); letter-spacing: -0.01em; }
.search__hit small { font-family: var(--f-mono); font-size: var(--t-xs); color: var(--c-ink-faint); }
.search__hit:hover, .search__hit[aria-selected="true"] { background: var(--c-surface-sunk); }
.search__hit[aria-selected="true"] small { color: var(--c-accent); }
.search__empty { padding: var(--s-4); color: var(--c-ink-faint); font-size: var(--t-sm); }

/* ---- tool card ---- */
.tool-card {
  display: flex; flex-direction: column; gap: var(--s-2);
  background: var(--c-surface); border: 1px solid var(--c-hair); border-radius: var(--r-md);
  padding: var(--s-5); box-shadow: var(--shadow-flat); position: relative; isolation: isolate;
  transition: border-color var(--dur-2) var(--ease), transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease);
}
.tool-card::before { content: ""; position: absolute; left: 0; top: var(--s-5); bottom: var(--s-5); width: 2px;
  background: var(--c-accent); border-radius: 2px; transform: scaleY(0); transform-origin: top; transition: transform var(--dur-3) var(--ease); }
.tool-card:hover { border-color: var(--c-hair-strong); transform: translateY(-3px); box-shadow: var(--shadow-lift); color: var(--c-ink); }
.tool-card:hover::before { transform: scaleY(1); }
.tool-card__tag { font-family: var(--f-mono); font-size: var(--t-xs); letter-spacing: 0.06em; text-transform: uppercase; color: var(--c-accent); }
.tool-card__name { font-family: var(--f-display); font-size: var(--t-md); font-weight: var(--w-semi); letter-spacing: -0.02em; }
.tool-card__formula { font-family: var(--f-mono); font-size: var(--t-xs); color: var(--c-ink-faint); margin-top: auto; padding-top: var(--s-2); }

/* ---- category card ---- */
.cat-card { background: var(--c-surface); border: 1px solid var(--c-hair); border-radius: var(--r-md); padding: var(--s-6); box-shadow: var(--shadow-flat);
  transition: border-color var(--dur-2) var(--ease), transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease); }
.cat-card:hover { border-color: var(--c-hair-strong); transform: translateY(-3px); box-shadow: var(--shadow-lift); color: var(--c-ink); }
.cat-card__idx { font-family: var(--f-mono); font-size: var(--t-xs); color: var(--c-ink-faint); border: 1px solid var(--c-hair-strong); width: 26px; height: 26px; display: grid; place-items: center; border-radius: var(--r-sm); }
.cat-card__title { font-size: var(--t-lg); margin: var(--s-4) 0 var(--s-2); letter-spacing: -0.025em; }
.cat-card__meta { font-size: var(--t-sm); color: var(--c-ink-soft); line-height: 1.5; }
.cat-card__count { font-family: var(--f-mono); font-size: var(--t-xs); color: var(--c-ink-faint); margin-top: var(--s-4); letter-spacing: 0.04em; }

/* ---- index list ---- */
.index-link { display: flex; justify-content: space-between; align-items: center; gap: var(--s-3); padding: var(--s-3) 0; border-bottom: var(--hair); font-size: var(--t-md); transition: padding-left var(--dur-2) var(--ease), color var(--dur-1) var(--ease); }
.index-link:hover { color: var(--c-accent); padding-left: var(--s-2); }
.index-link small { font-family: var(--f-mono); font-size: var(--t-xs); color: var(--c-ink-faint); }

/* ---- pills / badges ---- */
.pill { display: inline-flex; align-items: center; gap: 6px; font-family: var(--f-mono); font-size: var(--t-xs);
  letter-spacing: 0.03em; padding: 4px 10px; border-radius: 999px; border: 1px solid var(--c-hair-strong); }
.pill--low { color: var(--c-band-low); border-color: color-mix(in srgb, var(--c-band-low) 30%, var(--c-hair)); background: var(--c-neg-wash); }
.pill--avg { color: var(--c-band-avg); border-color: color-mix(in srgb, var(--c-band-avg) 30%, var(--c-hair)); background: var(--c-warn-wash); }
.pill--strong { color: var(--c-band-strong); border-color: color-mix(in srgb, var(--c-band-strong) 30%, var(--c-hair)); background: var(--c-pos-wash); }

/* ---- reserved content block (formerly ad slot) ---- */
.ad-slot {
  background: var(--c-surface-sunk); border: 1px solid var(--c-hair); border-radius: 0;
  box-shadow: var(--shadow-inset); padding: var(--s-5);
  display: grid; gap: var(--s-1); place-items: center; place-content: center; min-height: 104px; text-align: center;
  display: none !important;
}
.ad-slot__label { font-family: var(--f-mono); font-size: 0.625rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--c-ink-faint); opacity: 0.8; }
.ad-slot__note { font-size: var(--t-sm); color: var(--c-ink-faint); }
.ad-slot--rail { min-height: 280px; }

/* ---- related tools module ---- */
.related { display: grid; gap: var(--s-3); background: var(--c-surface); border: 1px solid var(--c-hair); border-radius: var(--r-md); padding: var(--s-5); box-shadow: var(--shadow-flat); }
.related__group { font-family: var(--f-mono); font-size: var(--t-xs); letter-spacing: 0.08em; text-transform: uppercase; color: var(--c-ink-faint); margin-top: var(--s-3); }
.related__group:first-child { margin-top: 0; }
.related__list { display: grid; gap: var(--s-2); }
.related__row { display: flex; justify-content: space-between; align-items: center; gap: var(--s-3); padding: var(--s-3) var(--s-3) var(--s-3) var(--s-4);
  border-radius: var(--r-sm); background: var(--c-surface-sunk); font-size: var(--t-sm); position: relative; min-width: 0;
  transition: background var(--dur-2) var(--ease), transform var(--dur-2) var(--ease); }
.related__row:hover { background: var(--c-accent-wash); transform: translateX(2px); color: var(--c-ink); }
.related__row > span:first-child { min-width: 0; overflow-wrap: anywhere; }
.related__kind { font-family: var(--f-mono); font-size: var(--t-xs); color: var(--c-ink-faint); flex: none; }

/* ---- brand ring mark (Brand Guidelines §16 lockup) ---- */
.brand__ring { width: 22px; height: 22px; flex: none; display: block; }
.site-foot .brand__ring { width: 19px; height: 19px; }
