
/* App SportsPress MVP - frontend base styles
 * Escopo: somente shortcodes do plugin. Não estiliza templates nativos do SportsPress.
 */
:root {
  --app-sp-primary: #39ff14;
  --app-sp-primary-strong: #20c90a;
  --app-sp-bg: #060806;
  --app-sp-card-bg: rgba(10, 16, 10, 0.94);
  --app-sp-card-bg-soft: rgba(255, 255, 255, 0.045);
  --app-sp-border: rgba(57, 255, 20, 0.30);
  --app-sp-border-soft: rgba(255, 255, 255, 0.14);
  --app-sp-text: inherit;
  --app-sp-muted: rgba(255, 255, 255, 0.72);
  --app-sp-success: #39ff14;
  --app-sp-success-bg: rgba(57, 255, 20, 0.12);
  --app-sp-success-border: rgba(57, 255, 20, 0.58);
  --app-sp-error: #ff4d4d;
  --app-sp-error-bg: rgba(255, 77, 77, 0.12);
  --app-sp-error-border: rgba(255, 77, 77, 0.62);
  --app-sp-warning: #ffbf3f;
  --app-sp-warning-bg: rgba(255, 191, 63, 0.13);
  --app-sp-warning-border: rgba(255, 191, 63, 0.60);
  --app-sp-radius: 16px;
  --app-sp-radius-sm: 10px;
  --app-sp-shadow: 0 18px 45px rgba(0, 0, 0, 0.35);
}

.app-sp-mvp-form,
.app-sp-mvp-free-team-form,
.app-sp-mvp-player-complement {
  box-sizing: border-box;
  width: 100%;
  max-width: 760px;
  margin: 0 auto 24px;
  padding: 22px;
  border: 1px solid var(--app-sp-border);
  border-radius: var(--app-sp-radius);
  background: linear-gradient(180deg, rgba(57,255,20,0.08), rgba(255,255,255,0.025)), var(--app-sp-card-bg);
  box-shadow: var(--app-sp-shadow);
  color: var(--app-sp-text);
  font-family: inherit;
}

.app-sp-mvp-form *,
.app-sp-mvp-free-team-form *,
.app-sp-mvp-player-complement * {
  box-sizing: border-box;
}

.app-sp-mvp-form h2,
.app-sp-mvp-free-team-form h2,
.app-sp-mvp-player-complement h2,
.app-sp-mvp-free-team-form h3,
.app-sp-mvp-player-complement h3 {
  margin-top: 0;
  margin-bottom: 10px;
  line-height: 1.15;
}

.app-sp-mvp-form p,
.app-sp-mvp-free-team-form p,
.app-sp-mvp-player-complement p {
  margin-top: 0;
}

.app-sp-mvp-field,
.app-sp-mvp-player-complement .app-sp-mvp-field,
.app-sp-mvp-free-team-form form > p {
  margin: 16px 0;
}

.app-sp-mvp-field label,
.app-sp-mvp-player-complement label,
.app-sp-mvp-free-team-form label {
  display: inline-block;
  margin-bottom: 7px;
  font-weight: 700;
  line-height: 1.25;
}

.app-sp-mvp-player-complement input[type="text"],
.app-sp-mvp-player-complement input[type="date"],
.app-sp-mvp-player-complement input[type="file"],
.app-sp-mvp-player-complement select,
.app-sp-mvp-player-complement textarea,
.app-sp-mvp-free-team-form input[type="text"],
.app-sp-mvp-free-team-form select,
.app-sp-mvp-free-team-form textarea {
  width: 100%;
  max-width: 100%;
  min-height: 42px;
  padding: 10px 12px;
  border: 1px solid var(--app-sp-border-soft);
  border-radius: var(--app-sp-radius-sm);
  background: rgba(0, 0, 0, 0.28);
  color: inherit;
  font-family: inherit;
  outline: none;
  transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.app-sp-mvp-player-complement select[multiple] {
  min-height: 130px;
}

.app-sp-mvp-player-complement input[type="file"] {
  height: auto;
  min-height: auto;
  padding: 12px;
  cursor: pointer;
}

.app-sp-mvp-player-complement input:focus,
.app-sp-mvp-player-complement select:focus,
.app-sp-mvp-player-complement textarea:focus,
.app-sp-mvp-free-team-form input:focus,
.app-sp-mvp-free-team-form select:focus,
.app-sp-mvp-free-team-form textarea:focus {
  border-color: var(--app-sp-primary);
  box-shadow: 0 0 0 3px rgba(57, 255, 20, 0.15);
}

.app-sp-mvp-player-complement small,
.app-sp-mvp-free-team-form small {
  color: var(--app-sp-muted);
  font-size: 0.88em;
}

.app-sp-mvp-player-complement fieldset,
.app-sp-mvp-free-team-form fieldset {
  margin: 18px 0;
  padding: 16px;
  border: 1px solid var(--app-sp-border-soft);
  border-radius: var(--app-sp-radius);
  background: var(--app-sp-card-bg-soft);
}

.app-sp-mvp-player-complement legend,
.app-sp-mvp-free-team-form legend {
  padding: 0 6px;
  font-weight: 700;
}

.app-sp-mvp-free-team-form form > p:has(input[type="radio"]) {
  padding: 14px;
  border: 1px solid var(--app-sp-border-soft);
  border-radius: var(--app-sp-radius-sm);
  background: rgba(255,255,255,0.035);
}

.app-sp-mvp-free-team-form input[type="radio"] {
  margin-right: 8px;
  accent-color: var(--app-sp-primary);
}

.app-sp-mvp-message {
  margin: 14px 0;
  padding: 13px 15px;
  border: 1px solid var(--app-sp-border-soft);
  border-left-width: 5px;
  border-radius: var(--app-sp-radius-sm);
  background: rgba(255, 255, 255, 0.05);
  color: inherit;
}

.app-sp-mvp-message p:last-child {
  margin-bottom: 0;
}

.app-sp-mvp-message-success {
  border-color: var(--app-sp-success-border);
  background: var(--app-sp-success-bg);
}

.app-sp-mvp-message-error {
  border-color: var(--app-sp-error-border);
  background: var(--app-sp-error-bg);
}

.app-sp-mvp-message-warning,
.app-sp-mvp-message-login {
  border-color: var(--app-sp-warning-border);
  background: var(--app-sp-warning-bg);
}

.app-sp-mvp-field-error input,
.app-sp-mvp-field-error select,
.app-sp-mvp-field-error fieldset {
  border-color: var(--app-sp-error) !important;
  box-shadow: 0 0 0 3px rgba(255,77,77,0.10);
}

.app-sp-mvp-field-message {
  display: block;
  margin-top: 7px;
  font-size: 0.92em;
  font-weight: 600;
}

.app-sp-mvp-field-message-error { color: var(--app-sp-error); }
.app-sp-mvp-field-message-success { color: var(--app-sp-success); }
.app-sp-mvp-field-message-warning { color: var(--app-sp-warning); }

.app-sp-mvp-form .button,
.app-sp-mvp-free-team-form .button,
.app-sp-mvp-player-complement .button,
.app-sp-mvp-message .button,
.app-sp-mvp-onboarding-actions .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 16px;
  border: 1px solid var(--app-sp-primary);
  border-radius: 999px;
  background: var(--app-sp-primary);
  color: #061006 !important;
  font-family: inherit;
  font-weight: 800;
  line-height: 1.1;
  text-decoration: none !important;
  cursor: pointer;
  transition: transform .14s ease, box-shadow .14s ease, filter .14s ease;
}

.app-sp-mvp-form .button:hover,
.app-sp-mvp-free-team-form .button:hover,
.app-sp-mvp-player-complement .button:hover,
.app-sp-mvp-message .button:hover,
.app-sp-mvp-onboarding-actions .button:hover {
  filter: brightness(1.05);
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(57, 255, 20, 0.18);
}

.app-sp-mvp-form .button:not(.button-primary),
.app-sp-mvp-free-team-form .button:not(.button-primary),
.app-sp-mvp-player-complement .button:not(.button-primary),
.app-sp-mvp-message .button:not(.button-primary),
.app-sp-mvp-onboarding-actions .button:not(.button-primary) {
  background: transparent;
  color: var(--app-sp-primary) !important;
}

.app-sp-mvp-onboarding-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.app-sp-mvp-photo-preview {
  width: 128px;
  height: 128px;
  object-fit: cover;
  border-radius: 18px;
  border: 1px solid var(--app-sp-border);
  display: block;
  margin-top: 10px;
  background: rgba(0,0,0,0.3);
}

.app-sp-mvp-photo-preview.is-new {
  border-color: var(--app-sp-success);
  box-shadow: 0 0 0 3px rgba(57, 255, 20, 0.14);
}

@media (max-width: 640px) {
  .app-sp-mvp-form,
  .app-sp-mvp-free-team-form,
  .app-sp-mvp-player-complement {
    padding: 16px;
    border-radius: 14px;
  }

  .app-sp-mvp-form .button,
  .app-sp-mvp-free-team-form .button,
  .app-sp-mvp-player-complement .button,
  .app-sp-mvp-message .button,
  .app-sp-mvp-onboarding-actions .button {
    width: 100%;
  }

  .app-sp-mvp-onboarding-actions {
    flex-direction: column;
  }
}
