/* ==========================================================================
   MTC Tennis — Component Library
   Phase 1A: Namespaced component classes only. No visual changes.

   All classes use the .mtc- prefix. None of these classes are referenced
   by current markup — they are ready for Phase 2 section-by-section
   migration.

   IMPORTANT: This file does NOT define or override broad selectors like
   .btn, .card, .form-control, .alert, .modal, etc.
   ========================================================================== */

/* ==========================================================================
   Buttons
   ========================================================================== */

.mtc-btn {
  font-family: var(--font-family, 'Inter', sans-serif);
  font-weight: var(--font-medium, 500);
  font-size: var(--text-base, 1rem);
  line-height: 1;
  padding: var(--space-3, 0.75rem) var(--space-6, 1.5rem);
  border-radius: var(--radius-md, 8px);
  border: 2px solid transparent;
  cursor: pointer;
  transition: background-color var(--transition-base, 0.2s ease),
              border-color var(--transition-base, 0.2s ease),
              transform 0.1s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2, 0.5rem);
  text-decoration: none;
  white-space: nowrap;
}

.mtc-btn:focus-visible {
  outline: 2px solid var(--color-accent, #00a8cc);
  outline-offset: 2px;
}

.mtc-btn-primary {
  background-color: var(--color-accent, #00a8cc);
  color: var(--color-white, #ffffff);
  border-color: var(--color-accent, #00a8cc);
}

.mtc-btn-primary:hover {
  background-color: var(--color-accent-hover, #0095b6);
  border-color: var(--color-accent-hover, #0095b6);
}

.mtc-btn-secondary {
  background-color: transparent;
  color: var(--color-accent, #00a8cc);
  border-color: var(--color-accent, #00a8cc);
}

.mtc-btn-secondary:hover {
  background-color: var(--color-accent-light, #e6f7fb);
}

.mtc-btn-ghost {
  background-color: transparent;
  color: var(--color-white, #ffffff);
  border-color: rgba(255, 255, 255, 0.5);
}

.mtc-btn-ghost:hover {
  background-color: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.8);
}

.mtc-btn-text {
  background: none;
  border: none;
  color: var(--color-accent, #00a8cc);
  padding: 0;
  font-weight: var(--font-medium, 500);
  text-decoration: none;
  cursor: pointer;
}

.mtc-btn-text:hover {
  text-decoration: underline;
}

/* ==========================================================================
   Cards
   ========================================================================== */

.mtc-card {
  background: var(--color-white, #ffffff);
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: var(--card-radius, 12px);
  padding: var(--card-padding, 1.5rem);
  transition: transform var(--transition-base, 0.2s ease),
              box-shadow var(--transition-base, 0.2s ease);
}

.mtc-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md, 0 4px 12px rgba(0, 0, 0, 0.08));
}

/* ==========================================================================
   Forms
   ========================================================================== */

.mtc-form-label {
  display: block;
  font-weight: var(--font-medium, 500);
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text, #1f2937);
  margin-bottom: var(--space-1, 0.25rem);
}

.mtc-form-control,
.mtc-form-select {
  display: block;
  width: 100%;
  height: var(--input-height, 48px);
  padding: var(--input-padding-y, 0.75rem) var(--input-padding-x, 1rem);
  font-family: var(--font-family, 'Inter', sans-serif);
  font-size: var(--text-base, 1rem);
  font-weight: var(--font-normal, 400);
  color: var(--color-text, #1f2937);
  background-color: var(--color-white, #ffffff);
  border: 1px solid var(--color-border-strong, #d1d5db);
  border-radius: var(--input-radius, 8px);
  transition: border-color var(--transition-fast, 0.15s ease),
              box-shadow var(--transition-fast, 0.15s ease);
  appearance: none;
}

.mtc-form-control:focus,
.mtc-form-select:focus {
  border-color: var(--color-accent, #00a8cc);
  box-shadow: 0 0 0 3px var(--color-accent-light, #e6f7fb);
  outline: none;
}

.mtc-form-control::placeholder {
  color: var(--color-text-disabled, #9ca3af);
}

.mtc-form-select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 16px 12px;
  padding-right: 2.5rem;
}

.mtc-form-error {
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-error, #dc2626);
  margin-top: var(--space-1, 0.25rem);
}

.mtc-form-help {
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-secondary, #6b7280);
  margin-top: var(--space-1, 0.25rem);
}

/* ==========================================================================
   Badges
   ========================================================================== */

.mtc-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1, 0.25rem) var(--space-3, 0.75rem);
  font-size: var(--text-xs, 0.75rem);
  font-weight: var(--font-semibold, 600);
  line-height: 1;
  border-radius: var(--radius-full, 9999px);
  white-space: nowrap;
  background-color: var(--color-accent-light, #e6f7fb);
  color: var(--color-primary, #0f3057);
}

/* ==========================================================================
   Alerts
   ========================================================================== */

.mtc-alert {
  padding: var(--space-4, 1rem) var(--space-5, 1.25rem);
  border-radius: var(--radius-md, 8px);
  border: none;
  font-size: var(--text-sm, 0.875rem);
  line-height: var(--leading-normal, 1.5);
}

.mtc-alert-info {
  background-color: var(--color-accent-light, #e6f7fb);
  color: var(--color-primary, #0f3057);
  border-left: 4px solid var(--color-accent, #00a8cc);
}

.mtc-alert-error {
  background-color: #fef2f2;
  color: #991b1b;
  border-left: 4px solid var(--color-error, #dc2626);
}

/* ==========================================================================
   Modals (namespaced)
   ========================================================================== */

.mtc-modal {
  border-radius: var(--card-radius, 12px);
  border: none;
  box-shadow: var(--shadow-xl, 0 20px 60px rgba(0, 0, 0, 0.15));
  overflow: hidden;
}

.mtc-modal-header {
  padding: var(--space-6, 1.5rem);
  border-bottom: 1px solid var(--color-border, #e5e7eb);
  background: linear-gradient(135deg, rgba(15, 48, 87, 0.05) 0%, rgba(15, 48, 87, 0.02) 100%);
}

.mtc-modal-header h5 {
  font-weight: var(--font-semibold, 600);
  color: var(--color-primary, #0f3057);
  font-size: var(--text-xl, 1.25rem);
  margin: 0;
}

.mtc-modal-body {
  padding: var(--space-6, 1.5rem);
  line-height: var(--leading-normal, 1.5);
}

.mtc-modal-footer {
  padding: var(--space-4, 1rem) var(--space-6, 1.5rem);
  border-top: 1px solid var(--color-border, #e5e7eb);
  background-color: var(--color-bg-alt, #fafafa);
}
