/* input(90,1): run-time error CSS1019: Unexpected token, found '}' */
/* --- Signup modal + drag-a-bottle captcha --- */
.signup-open-btn { margin-top: var(--space-sm); }

.signup-modal { position: fixed; inset: 0; z-index: 1000; display: flex;
  align-items: center; justify-content: center; padding: var(--space-md); }
.signup-modal[hidden] { display: none; }
.signup-modal__backdrop { position: absolute; inset: 0; background: rgba(13,14,28,.62); }
.signup-modal__content { position: relative; background: var(--color-bg);
  color: var(--color-text); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
  width: 100%; max-width: 400px; max-height: 92vh; overflow-y: auto; overflow-x: hidden;
  padding: var(--space-lg); }
.signup-modal__close { position: absolute; top: var(--space-sm); right: var(--space-sm);
  background: none; border: 0; color: var(--color-muted); cursor: pointer; padding: var(--space-xs); }
.signup-modal__close:hover { color: var(--color-text); }
.signup-modal__title { margin: 0 var(--space-lg) var(--space-xs) 0; font-family: var(--font-display);
  font-size: 1.4rem; font-weight: 700; line-height: 1.2; letter-spacing: -0.01em; }
.signup-modal__sub { margin: 0 0 var(--space-md); color: var(--color-text-secondary); font-size: .9rem; }

.signup-field { margin-bottom: var(--space-sm); }
.signup-field label { display: block; margin-bottom: var(--space-xs); font-weight: 600; }
.signup-optional { font-weight: 400; color: var(--color-muted); }
.signup-modal .signup-input { width: 100%; padding: .6rem .75rem;
  border: 1px solid var(--color-surface-alt); border-radius: var(--radius-md);
  background: var(--color-surface); color: var(--color-text); font: inherit; }
.signup-modal .signup-input:focus { outline: 2px solid var(--color-accent); outline-offset: 1px; }
.signup-modal .signup-input[aria-invalid="true"],
.signup-modal .signup-input:user-invalid { border-color: var(--color-error); }
textarea.signup-input { resize: vertical; }
.signup-field__error { display: block; min-height: 1.1em; margin-top: var(--space-xs);
  font-size: .8rem; color: var(--color-error); }

.signup-captcha { max-width: 300px; margin: 0 auto var(--space-md); }
.signup-captcha__stage { position: relative; width: 100%; aspect-ratio: 300 / 180;
  border-radius: var(--radius-md); overflow: hidden; background: var(--color-surface); }
.signup-captcha__bg { width: 100%; height: 100%; display: block; user-select: none; }
.signup-captcha__piece { position: absolute; top: 0; left: 0; will-change: left;
  /* 1px light outline tracing the bottle's alpha edge (4 offset drop-shadows) so the
     silhouette reads clearly on any background, plus a soft shadow for depth. */
  filter: drop-shadow(1px 0 0 rgba(255,255,255,.9)) drop-shadow(-1px 0 0 rgba(255,255,255,.9))
          drop-shadow(0 1px 0 rgba(255,255,255,.9)) drop-shadow(0 -1px 0 rgba(255,255,255,.9))
          drop-shadow(0 2px 5px rgba(0,0,0,.5));
  user-select: none; touch-action: none; }
.signup-captcha__track { position: relative; height: 12px; margin: var(--space-sm) 0 var(--space-xs);
  border-radius: var(--radius-full); background: var(--color-surface-alt); }
.signup-captcha__handle { position: absolute; top: 50%; transform: translateY(-50%);
  left: 0; width: 40px; height: 28px; border: 0; border-radius: var(--radius-md);
  background: var(--color-accent); cursor: grab; touch-action: none; }
/* Invisible ~44x44 tap area for thumb users; keeps the visible handle sleek. */
.signup-captcha__handle::before { content: ""; position: absolute; inset: -8px -2px; }
.signup-captcha__handle:focus-visible { outline: 2px solid var(--color-text); outline-offset: 2px; }
.signup-captcha.is-solved .signup-captcha__handle { background: var(--color-success); cursor: default; }
.signup-captcha.is-failed .signup-captcha__handle { background: var(--color-error); }
.signup-captcha__footer { display: flex; justify-content: space-between; align-items: center; gap: var(--space-sm); }
.signup-captcha__status { font-size: .85rem; color: var(--color-text-secondary); }
.signup-captcha.is-solved .signup-captcha__status { color: var(--color-success); }
.signup-captcha__refresh { background: none; border: 0; color: var(--color-accent);
  cursor: pointer; font-size: .85rem; }

.signup-modal__submit { width: 100%; }
.signup-modal__submit:disabled { opacity: .55; cursor: not-allowed; }
/* Submit busy state (HTMX adds .htmx-request during the POST; hx-disabled-elt also
   disables the button, preventing a double-submit). Reuses the global spin keyframe. */
.signup-modal__spinner { display: none; width: 1em; height: 1em; margin-left: .5em;
  border: 2px solid currentColor; border-right-color: transparent; border-radius: 50%;
  vertical-align: -.15em; animation: spin .7s linear infinite; }
.signup-modal__submit.htmx-request .signup-modal__spinner { display: inline-block; }
.signup-modal__submit.htmx-request .signup-modal__submit-label { opacity: .85; }
.signup-modal__privacy { margin-top: var(--space-md); font-size: .8rem; color: var(--color-muted); }

#signup-modal-result { margin-top: var(--space-md); text-align: center; }
#signup-modal-result .signup-success { color: var(--color-success); font-weight: 500; }
#signup-modal-result .signup-error { color: var(--color-error); }

.search-no-results__msg { margin-bottom: var(--space-sm); }
.search-no-results__cta { display: inline-block; margin-top: var(--space-xs);
  background: none; border: 0; padding: 0; color: var(--color-accent);
  font-size: .95rem; font-weight: 600; cursor: pointer; text-decoration: none; }
.search-no-results__cta:hover { text-decoration: underline; }

/* Entrance motion - gentle fade + rise on open, ease-out (no bounce). Skipped for
   reduced-motion users. The modal toggles via [hidden], so removing it replays this. */
@media (prefers-reduced-motion: no-preference) {
  .signup-modal:not([hidden]) .signup-modal__backdrop { animation: signup-modal-fade 180ms ease-out; }
  .signup-modal:not([hidden]) .signup-modal__content {
    animation: signup-modal-rise 220ms cubic-bezier(0.22, 1, 0.36, 1); }
  @keyframes signup-modal-fade { from { opacity: 0; } to { opacity: 1; } }
  @keyframes signup-modal-rise {
    from { opacity: 0; transform: translateY(10px) scale(.985); }
    to { opacity: 1; transform: none; } }
}
