/* Expiry picker — reusable widget for selecting a future-time. Always
   emits an absolute ISO timestamp; callers convert to duration if their
   API expects seconds. Sites: tenant PATs, api-explorer PATs, cache
   rule TTLs (and any future expiry needs).

   Rendered into any container element via mountExpiryPicker(). All
   layout is self-contained — caller only owns label/wrapper around it. */

.expiry-picker {
  display: flex;
  flex-direction: column;
  gap: var(--s-12);
}

.expiry-picker-pills {
  display: flex;
  gap: var(--s-8);
  flex-wrap: wrap;
}

.expiry-picker-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px var(--s-12);
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  background: var(--card-bg);
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--motion);
}
.expiry-picker-pill:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.expiry-picker-pill.is-active {
  background: var(--accent-gradient);
  border-color: transparent;
  color: #fff;
}

.expiry-picker-panel {
  padding: var(--s-16);
  background: var(--code-bg);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  gap: var(--s-12);
}

.expiry-picker-note {
  margin: 0;
  display: flex;
  align-items: center;
  gap: var(--s-8);
  color: var(--text);
  font-size: 13px;
}
.expiry-picker-note i { color: var(--accent); }

.expiry-picker-preset-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: var(--s-8);
}

.expiry-picker-preset {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: var(--s-12);
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background: var(--card-bg);
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--motion);
}
.expiry-picker-preset i {
  font-size: 16px;
  color: var(--muted);
}
.expiry-picker-preset:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.expiry-picker-preset:hover i { color: var(--accent); }
.expiry-picker-preset.is-selected {
  border-color: var(--accent);
  background: var(--hover-bg);
  color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent-shadow);
}
.expiry-picker-preset.is-selected i { color: var(--accent); }

.expiry-picker-relative-grid,
.expiry-picker-absolute-grid {
  display: grid;
  gap: var(--s-12);
}
.expiry-picker-relative-grid { grid-template-columns: repeat(auto-fit, minmax(80px, 1fr)); }
.expiry-picker-absolute-grid { grid-template-columns: 1fr 1fr; }

.expiry-picker-relative-grid label,
.expiry-picker-absolute-grid label {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}
.expiry-picker-input-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}

.expiry-picker-preview {
  margin: 0;
  display: flex;
  align-items: center;
  gap: var(--s-8);
  font-size: 13px;
  color: var(--text);
}
.expiry-picker-preview i { color: var(--accent); }
.expiry-picker-preview strong { color: var(--text-strong); }

@media (max-width: 540px) {
  .expiry-picker-relative-grid { grid-template-columns: 1fr; }
  .expiry-picker-absolute-grid { grid-template-columns: 1fr; }
}
