/* Global, reusable component styles (unlayered to outrank Bootstrap) */
/* Width token (local). Consider moving to design-tokens.css if reused broadly */
:root { --btn-token-fixed-width: 18rem; }
/* Primary button using semantic tokens */
button.btn-primary-token,
a.btn-primary-token {
  font-size: var(--font-size-base);
  font-family: var(--font-family-sans);
  display: inline-block;
  margin: 0.5rem;
  padding: var(--space-4) var(--space-4);
  border-radius: var(--radius-md, 8px);
  background: var(--color-primary, #165C84);
  color: var(--color-surface, #ffffff);
  text-decoration: none;
  font-weight: 600;
  border: 1px solid transparent;
  box-shadow: var(--elevation-card, 0 1px 2px rgba(20, 26, 51, 0.06), 0 2px 6px rgba(20, 26, 51, 0.05));
  transition: transform 20ms ease, filter var(--transition-base, 150ms ease);
  width: var(--btn-token-fixed-width); /* ensure consistent width on wider screens */
  text-align: center;
}
.btn-primary-token:hover { background: var(--color-primary-hover, #124A69); }
.btn-primary-token:active { transform: translateY(1px); }
.btn-primary-token:focus-visible { outline: 2px solid rgba(22,92,132,0.3); outline-offset: 2px; }

/* Secondary button on neutral surface */
button.btn-secondary-token,
a.btn-secondary-token {
  font-size: var(--font-size-base);
  font-family: var(--font-family-sans);
  display: inline-block;
  margin: 0.5rem;
  padding: var(--space-4) var(--space-4);
  border-radius: var(--radius-md, 8px);
  background: var(--color-surface, #ffffff);
  color: var(--color-primary, #165C84);
  border: 1px solid var(--color-border, #DADEF2);
  text-decoration: none;
  font-weight: 600;
  box-shadow: var(--elevation-card, 0 1px 2px rgba(20, 26, 51, 0.06), 0 2px 6px rgba(20, 26, 51, 0.05));
  width: var(--btn-token-fixed-width);
  text-align: center;
}
.btn-secondary-token:hover { background: var(--color-surface, #FAFBFE); }
.btn-secondary-token:focus-visible { outline: 2px solid rgba(22,92,132,0.25); outline-offset: 2px; }

.dropdown-item {
  font-family: var(--font-family-sans);
  font-size: var(--font-size-base);
}

/* Mobile: make buttons span full width for easier tapping */
@media (max-width: 600px) {
  button.btn-primary-token,
  a.btn-primary-token,
  button.btn-secondary-token,
  a.btn-secondary-token {
    display: block;              /* stack */
    width: 100%;                 /* mobile still full-width for accessibility */
    margin: var(--space-2) 0; /* vertical rhythm, no horizontal gap */
  }
}
