/* =============================================================
   SUF National Recruiting Board — Recruiting Fields Plugin
   Single sp_player profile — dark ESPN-style theme
   ============================================================= */

/* ── Variables ────────────────────────────────────────────────── */
:root {
  --suf-bg:       #0d1117;
  --suf-card:     #161b22;
  --suf-raised:   #21262d;
  --suf-border:   #30363d;
  --suf-text:     #e6edf3;
  --suf-muted:    #8b949e;
  --suf-orange:   #e05c00;
  --suf-orange-h: #ff7a20;

  --elite:    #ffd700;
  --national: #c0c0c0;
  --regional: #cd7f32;

  --r-sm: 6px;
  --r-md: 14px;
  --r-lg: 20px;
  --card-shadow: 0 10px 52px rgba(0,0,0,.72);
}

/* ── Scoped reset ─────────────────────────────────────────────── */
.suf-profile-page *,
.suf-profile-page *::before,
.suf-profile-page *::after {
  box-sizing: border-box;
}

/* =============================================================
   PAGE ROOT
   ============================================================= */
.suf-profile-page {
  background: var(--suf-bg);
  min-height: 100vh;
  color: var(--suf-text);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: 15px;
  line-height: 1.5;
  width: 100%;
}

/* =============================================================
   HERO STRIP — 280px full-bleed blurred banner
   100vw + left:50% + translateX(-50%) breaks out of any
   max-width theme container safely (parent has no overflow:hidden)
   ============================================================= */
.suf-hero-strip {
  position: relative;
  height: 280px;
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  overflow: hidden;
}
.suf-hero-bg {
  position: absolute;
  inset: -30px;
  background-size: cover;
  background-position: center top;
  filter: blur(16px) brightness(.22) saturate(1.6);
  transform: scale(1.08);
}
.suf-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(13,17,23,.1)   0%,
    rgba(13,17,23,.72) 62%,
    rgba(13,17,23,1)  100%
  );
}

/* =============================================================
   MAIN WRAP — pulls up 200px to overlap hero
   ============================================================= */
.suf-main-wrap {
  position: relative;
  z-index: 10;
  max-width: 1120px;
  margin: -200px auto 0;
  padding: 0 24px 72px;
}

/* =============================================================
   MAIN CARD — two-column grid
   ============================================================= */
.suf-card {
  display: grid;
  grid-template-columns: 280px 1fr;
  background: var(--suf-card);
  border: 1px solid var(--suf-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--card-shadow);
  margin-bottom: 24px;
  animation: suf-fadein .45s ease both;
}

/* =============================================================
   LEFT COLUMN
   Order: photo → tier ribbon → score → stars → Hudl
   ============================================================= */
.suf-col-left {
  background: var(--suf-raised);
  border-right: 1px solid var(--suf-border);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 28px 20px 24px;
  gap: 16px;
}

/* 1. Photo frame — 3:4 */
.suf-photo-frame {
  width: 100%;
  aspect-ratio: 3 / 4;
  border-radius: var(--r-md);
  overflow: hidden;
  border: 2px solid var(--suf-border);
  box-shadow: 0 4px 24px rgba(0,0,0,.55);
  background: var(--suf-bg);
  flex-shrink: 0;
}
.suf-photo-img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center top;
}
.suf-photo-img--helmet {
  object-fit: contain;
  padding: 14px 10px 8px;
  background: var(--suf-bg);
}

/* 2. Tier ribbon */
.suf-tier-ribbon {
  width: 100%;
  text-align: center;
  padding: 8px 12px;
  border-radius: var(--r-sm);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.suf-tier-ribbon.tier-elite    { background: rgba(255,215,0,.12);   color: var(--elite);    border: 1px solid rgba(255,215,0,.38); }
.suf-tier-ribbon.tier-national { background: rgba(192,192,192,.12); color: var(--national); border: 1px solid rgba(192,192,192,.38); }
.suf-tier-ribbon.tier-regional { background: rgba(205,127,50,.12);  color: var(--regional); border: 1px solid rgba(205,127,50,.38); }

/* 3 + 4. Score block */
.suf-score-block { text-align: center; line-height: 1; }
.suf-score-num {
  font-size: 72px;
  font-weight: 900;
  letter-spacing: -.03em;
  font-feature-settings: "tnum";
  line-height: 1;
}
.suf-score-num.tier-elite    { color: var(--elite); }
.suf-score-num.tier-national { color: var(--national); }
.suf-score-num.tier-regional { color: var(--regional); }
.suf-score-lbl {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--suf-muted);
  margin-top: 5px;
}

/* 4. Stars */
.suf-stars {
  display: flex;
  gap: 4px;
  justify-content: center;
}
.suf-star {
  width: 20px;
  height: 20px;
  stroke: var(--elite);
  stroke-width: 1.5;
  overflow: visible;
  flex-shrink: 0;
}
.suf-star--full  { fill: var(--elite); }
.suf-star--half  { fill: none; }
.suf-star--empty { fill: none; }

/* 5. Hudl button */
.suf-hudl-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  background: var(--suf-orange);
  color: #fff !important;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 13px 16px;
  border-radius: var(--r-sm);
  text-decoration: none !important;
  border: none !important;
  cursor: pointer;
  transition: background .18s ease, transform .15s ease;
  margin-top: auto;
}
.suf-hudl-btn:hover {
  background: var(--suf-orange-h);
  transform: translateY(-2px);
  color: #fff !important;
}

/* =============================================================
   RIGHT COLUMN
   ============================================================= */
.suf-col-right {
  padding: 32px 36px 32px;
  display: flex;
  flex-direction: column;
  gap: 26px;
}

/* Nameplate */
.suf-nameplate {
  padding-bottom: 20px;
  border-bottom: 1px solid var(--suf-border);
}
.suf-name {
  font-size: 48px !important;
  font-weight: 900 !important;
  line-height: 1.0 !important;
  margin: 0 0 12px !important;
  padding: 0 !important;
  color: #fff !important;
  border: none !important;
  text-shadow: none !important;
  letter-spacing: -.01em;
}
.suf-nameplate-sub {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  color: var(--suf-muted);
}
.suf-pos-pill {
  background: var(--suf-orange);
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 4px 13px;
  border-radius: 4px;
}
.suf-sep { opacity: .3; font-size: 18px; }

/* Physicals stats bar */
.suf-physicals {
  display: flex;
  align-items: stretch;
  background: var(--suf-raised);
  border: 1px solid var(--suf-border);
  border-radius: var(--r-sm);
  overflow: hidden;
}
.suf-phys-cell {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 16px 10px;
}
.suf-phys-val {
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  line-height: 1;
  white-space: nowrap;
}
.suf-phys-lbl {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--suf-muted);
}
.suf-phys-div {
  width: 1px;
  background: var(--suf-border);
  align-self: stretch;
  flex-shrink: 0;
}

/* =============================================================
   SCOUTING REPORT (ratings + lock overlay)
   ============================================================= */
.suf-scouting { position: relative; }

.suf-section-title {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--suf-muted) !important;
  margin: 0 0 16px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--suf-border) !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}

/* Ratings list */
.suf-ratings-list {
  display: flex;
  flex-direction: column;
  gap: 13px;
}

/* label | animated bar | score | grade */
.suf-rating-row {
  display: grid;
  grid-template-columns: 110px 1fr 44px 36px;
  align-items: center;
  gap: 12px;
}
.suf-rating-label {
  font-size: 13px;
  color: var(--suf-muted);
  white-space: nowrap;
}
.suf-bar-track {
  height: 8px;
  background: var(--suf-bg);
  border: 1px solid var(--suf-border);
  border-radius: 4px;
  overflow: hidden;
}
.suf-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--suf-orange) 0%, #ff9a50 100%);
  border-radius: 4px;
  transition: width .78s cubic-bezier(.25,.8,.25,1);
  will-change: width;
}
.suf-rating-num {
  font-size: 14px;
  font-weight: 700;
  text-align: right;
  color: var(--suf-text);
  font-feature-settings: "tnum";
}

/* Grade badges */
.suf-grade {
  font-size: 11px;
  font-weight: 800;
  text-align: center;
  border-radius: 4px;
  padding: 2px 5px;
  min-width: 30px;
}
.grade-aplus, .grade-a, .grade-aminus { background: rgba(0,200,83,.14);   color: #00c853; }
.grade-bplus, .grade-b, .grade-bminus { background: rgba(66,165,245,.14); color: #42a5f5; }
.grade-cplus, .grade-c, .grade-cminus { background: rgba(255,215,0,.14);  color: #ffd740; }
.grade-dplus, .grade-d               { background: rgba(255,82,82,.14);   color: #ff5252; }
.grade-f                              { background: rgba(213,0,0,.18);    color: #ff1744; }
.grade-none                           { background: transparent; color: var(--suf-muted); }

/* Tier description blurb */
.suf-tier-blurb {
  margin-top: 18px;
  padding: 13px 16px;
  border-radius: var(--r-sm);
  font-size: 13px;
  line-height: 1.6;
  color: var(--suf-text);
}
.suf-tier-blurb.tier-elite    { background: rgba(255,215,0,.07);   border-left: 3px solid var(--elite); }
.suf-tier-blurb.tier-national { background: rgba(192,192,192,.07); border-left: 3px solid var(--national); }
.suf-tier-blurb.tier-regional { background: rgba(205,127,50,.07);  border-left: 3px solid var(--regional); }
.suf-tier-blurb strong { display: block; margin-bottom: 4px; font-weight: 700; }

/* ── Free-tier lock overlay ── */
.suf-scouting--locked .suf-ratings-list,
.suf-scouting--locked .suf-tier-blurb {
  filter: blur(5px);
  user-select: none;
  pointer-events: none;
}
.suf-lock-overlay {
  position: absolute;
  inset: 42px 0 0;  /* below the section title */
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(13,17,23,.6);
  backdrop-filter: blur(2px);
  border-radius: var(--r-sm);
  z-index: 5;
}
.suf-lock-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 24px 32px;
  background: var(--suf-raised);
  border: 1px solid var(--suf-border);
  border-radius: var(--r-md);
  text-align: center;
  box-shadow: 0 4px 24px rgba(0,0,0,.5);
  color: var(--suf-text);
}
.suf-lock-badge svg { color: var(--suf-orange); margin-bottom: 4px; }
.suf-lock-badge span {
  font-size: 15px;
  font-weight: 700;
  color: var(--suf-text);
}
.suf-lock-badge em {
  font-style: normal;
  font-size: 12px;
  color: var(--suf-muted);
}

/* =============================================================
   LOWER CARDS — Scout's Notes / Detailed Analysis
   ============================================================= */
.suf-lower {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.suf-lower-card {
  background: #13131a;
  border: 1px solid var(--suf-border);
  border-left: 3px solid #D4AF37;
  border-radius: var(--r-md);
  padding: 24px 28px;
  animation: suf-fadein .45s ease .15s both;
}
.suf-lower-title {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: #D4AF37 !important;
  margin: 0 0 16px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--suf-border) !important;
  border-top: none !important; border-left: none !important; border-right: none !important;
}
.suf-lower-body {
  font-size: 15px;
  line-height: 1.8;
  color: var(--suf-text);
}

/* ── Video embed wrapper — responsive 16:9 ── */
.suf-video-wrap {
  position: relative;
  width: 100%;
  padding-top: 56.25%; /* 16:9 */
  border-radius: var(--r-sm);
  overflow: hidden;
  background: #000;
}
.suf-video-wrap iframe,
.suf-video-wrap video,
.suf-video-wrap object,
.suf-video-wrap embed {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  border: none;
}
/* Fallback button when oEmbed is unavailable */
.suf-video-fallback-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--suf-orange);
  color: #fff !important;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 12px 20px;
  border-radius: var(--r-sm);
  text-decoration: none !important;
  transition: background .18s ease;
}
.suf-video-fallback-btn:hover {
  background: var(--suf-orange-h);
  color: #fff !important;
}

/* ── SportsPress content inside Detailed Analysis ── */
/* Override all light backgrounds, borders, and text colours that SP injects */
.suf-sp-content,
.suf-sp-content * {
  color: var(--suf-text) !important;
  background: transparent !important;
  border-color: var(--suf-border) !important;
}
/* SP section headings */
.suf-sp-content h2,
.suf-sp-content h3,
.suf-sp-content h4 {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
  color: #D4AF37 !important;
  margin-top: 24px !important;
  margin-bottom: 12px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid var(--suf-border) !important;
}
/* SP data tables */
.suf-sp-content table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  margin-bottom: 16px;
}
.suf-sp-content thead th {
  background: var(--suf-raised) !important;
  color: var(--suf-muted) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  padding: 8px 12px !important;
  border: 1px solid var(--suf-border) !important;
  text-align: left;
}
.suf-sp-content tbody td {
  padding: 8px 12px !important;
  border: 1px solid var(--suf-border) !important;
  color: var(--suf-text) !important;
}
.suf-sp-content tbody tr:nth-child(even) td {
  background: rgba(255,255,255,.03) !important;
}
.suf-sp-content tbody tr:hover td {
  background: rgba(255,255,255,.06) !important;
}
/* SP biography / article block */
.suf-sp-content .sp-player-section,
.suf-sp-content .sp-section,
.suf-sp-content article,
.suf-sp-content .entry-content {
  background: transparent !important;
  color: var(--suf-text) !important;
}
/* SP links */
.suf-sp-content a {
  color: var(--suf-orange) !important;
  text-decoration: none !important;
}
.suf-sp-content a:hover {
  color: var(--suf-orange-h) !important;
  text-decoration: underline !important;
}
/* Remove any white/light box shadows SP adds */
.suf-sp-content .sp-template,
.suf-sp-content .sp-player-statistics,
.suf-sp-content .sp-performance {
  box-shadow: none !important;
  background: transparent !important;
  border: 1px solid var(--suf-border) !important;
  border-radius: var(--r-sm) !important;
  padding: 0 !important;
  margin-bottom: 16px !important;
  overflow: hidden !important;
}

/* =============================================================
   ANIMATION
   ============================================================= */
@keyframes suf-fadein {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* =============================================================
   RESPONSIVE
   ============================================================= */

/* Tablet — stack columns, photo side-by-side with score */
@media (max-width: 860px) {
  .suf-card { grid-template-columns: 1fr; }
  .suf-col-left {
    border-right: none;
    border-bottom: 1px solid var(--suf-border);
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    padding: 20px;
    gap: 16px;
  }
  .suf-photo-frame {
    width: 150px;
    aspect-ratio: 3 / 4;
    flex-shrink: 0;
  }
  .suf-tier-ribbon,
  .suf-score-block,
  .suf-stars,
  .suf-hudl-btn {
    width: calc(100% - 150px - 16px);
    flex-shrink: 0;
  }
  .suf-score-num { font-size: 56px; }
  .suf-stars { justify-content: flex-start; }
  .suf-hudl-btn { margin-top: 0; }
  .suf-col-right { padding: 24px 20px; }
  .suf-name { font-size: 34px !important; }
}

/* Mobile — full-width photo, single column */
@media (max-width: 580px) {
  .suf-hero-strip { height: 200px; }
  .suf-main-wrap { margin-top: -160px; padding: 0 12px 48px; }
  .suf-col-left { flex-direction: column; align-items: center; }
  .suf-photo-frame { width: 100%; max-height: 280px; aspect-ratio: 3 / 4; }
  .suf-tier-ribbon,
  .suf-score-block,
  .suf-stars,
  .suf-hudl-btn { width: 100%; }
  .suf-score-num { font-size: 64px; }
  .suf-stars { justify-content: center; }
  .suf-col-right { padding: 20px 16px; gap: 20px; }
  .suf-name { font-size: 28px !important; }
  .suf-rating-row { grid-template-columns: 90px 1fr 38px 30px; gap: 8px; }
  .suf-physicals { flex-wrap: wrap; }
  .suf-phys-cell { min-width: 30%; }
}


/* ── Login page dark theme fix ──────────────────────────────────────────────
   Targets the WPUF login form on pages with slug /login/
   Body class: .page-id-XXXX is unreliable; we use the WPUF wrapper ID
   #wpuf-login-form which only appears on pages using [wpuf_login].
   ────────────────────────────────────────────────────────────────────────── */

#wpuf-login-form {
  background: #13131a;
  border: 1px solid #2a2a3a;
  border-radius: 8px;
  padding: 32px 28px;
  max-width: 420px;
  margin: 40px auto;
}

/* Labels */
#wpuf-login-form label {
  color: #d0d0d8 !important;
  font-size: .9rem;
  font-weight: 600;
  display: block;
  margin-bottom: 5px;
}

/* Text / password inputs */
#wpuf-login-form input.input,
#wpuf-login-form input[type="text"],
#wpuf-login-form input[type="password"],
#wpuf-login-form input[type="email"] {
  background: #1e1e2e !important;
  color: #f0f0f5 !important;
  border: 1px solid #3a3a50 !important;
  border-radius: 5px;
  padding: 10px 12px;
  width: 100%;
  box-sizing: border-box;
  font-size: .95rem;
  outline: none;
  transition: border-color .2s;
}

#wpuf-login-form input.input:focus,
#wpuf-login-form input[type="text"]:focus,
#wpuf-login-form input[type="password"]:focus {
  border-color: #D4AF37 !important;
  box-shadow: 0 0 0 2px rgba(212,175,55,.15);
}

/* Placeholder text */
#wpuf-login-form input::placeholder {
  color: #666680 !important;
  opacity: 1;
}

/* Remember me + Lost password row */
#wpuf-login-form .wpuf-remember-forgot-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 14px 0;
}

#wpuf-login-form .wpuf-remember-me label,
#wpuf-login-form .forgetmenot label {
  color: #a0a0b8 !important;
  font-weight: 400;
}

#wpuf-login-form .wpuf-lost-password a {
  color: #D4AF37 !important;
  font-size: .85rem;
  text-decoration: none;
}

#wpuf-login-form .wpuf-lost-password a:hover {
  text-decoration: underline;
}

/* Submit button */
#wpuf-login-form input[type="submit"],
#wpuf-login-form #wp-submit {
  background: #D4AF37 !important;
  color: #0a0a0f !important;
  border: none !important;
  border-radius: 5px;
  padding: 11px 28px;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  width: 100%;
  transition: filter .2s;
}

#wpuf-login-form input[type="submit"]:hover {
  filter: brightness(1.1);
}

/* Register / action links below the form */
#wpuf-login-form .wpuf-action-links,
.wpuf-action-links {
  text-align: center;
  margin-top: 16px;
  font-size: .85rem;
  color: #888 !important;
}

#wpuf-login-form .wpuf-action-links a,
.wpuf-action-links a {
  color: #D4AF37 !important;
  text-decoration: none;
}

#wpuf-login-form .wpuf-action-links a:hover {
  text-decoration: underline;
}

/* Error / message notices inside the form */
#wpuf-login-form .wpuf-error,
#wpuf-login-form .wpuf-message {
  background: #2a1520;
  border-left: 3px solid #e05260;
  color: #f5a0a8 !important;
  padding: 10px 14px;
  border-radius: 4px;
  margin-bottom: 16px;
  font-size: .875rem;
}

/* p spacing */
#wpuf-login-form p {
  margin: 0 0 14px;
}


/* ═══════════════════════════════════════════════════════════════════════════
   WPUF REGISTRATION FORM — dark theme, remove bullets
   Selectors: #wpuf-registration-form, .wpuf-registration-form,
              .wpuf-form ul / li (bullet removal)
   ═══════════════════════════════════════════════════════════════════════════ */

/* Strip list styling from every WPUF form */
.wpuf-form ul,
.wpuf-form ol,
.wpuf-registration-form ul,
.wpuf-registration-form ol,
#wpuf-registration-form ul,
#wpuf-registration-form ol,
#registrationform ul,
#registrationform ol {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.wpuf-form li,
.wpuf-registration-form li,
#wpuf-registration-form li,
#registrationform li {
  list-style: none !important;
  list-style-type: none !important;
  padding-left: 0 !important;
  margin-bottom: 18px !important;
}

.wpuf-form li::before,
.wpuf-form li::marker,
.wpuf-registration-form li::before,
.wpuf-registration-form li::marker,
#wpuf-registration-form li::before,
#wpuf-registration-form li::marker {
  display: none !important;
  content: none !important;
}

/* Form wrapper */
#wpuf-registration-form,
.wpuf-registration-form-wrap {
  background: #13131a;
  border: 1px solid #2a2a3a;
  border-radius: 8px;
  padding: 32px 28px;
  max-width: 520px;
  margin: 40px auto;
}

/* Field labels (.wpuf-label is the main label div) */
#wpuf-registration-form .wpuf-label,
#wpuf-registration-form label,
.wpuf-registration-form .wpuf-label,
.wpuf-registration-form label {
  color: #d0d0d8 !important;
  font-size: .875rem;
  font-weight: 600;
  display: block;
  margin-bottom: 5px;
}

/* Sub-labels (First / Last below name split) */
#wpuf-registration-form .wpuf-form-sub-label,
.wpuf-registration-form .wpuf-form-sub-label {
  color: #666680 !important;
  font-size: .75rem;
  font-weight: 400;
  margin-top: 3px;
}

/* Required star */
#wpuf-registration-form .required,
.wpuf-registration-form .required {
  color: #e05260 !important;
}

/* All text / password / email inputs */
#wpuf-registration-form input.input,
#wpuf-registration-form input[type="text"],
#wpuf-registration-form input[type="password"],
#wpuf-registration-form input[type="email"],
.wpuf-registration-form input.input,
.wpuf-registration-form input[type="text"],
.wpuf-registration-form input[type="password"],
.wpuf-registration-form input[type="email"] {
  background: #1e1e2e !important;
  color: #f0f0f5 !important;
  border: 1px solid #3a3a50 !important;
  border-radius: 5px;
  padding: 10px 12px;
  width: 100%;
  box-sizing: border-box;
  font-size: .95rem;
  outline: none;
  transition: border-color .2s, box-shadow .2s;
}

#wpuf-registration-form input.input:focus,
#wpuf-registration-form input[type="text"]:focus,
#wpuf-registration-form input[type="password"]:focus,
.wpuf-registration-form input.input:focus {
  border-color: #D4AF37 !important;
  box-shadow: 0 0 0 2px rgba(212,175,55,.15) !important;
}

#wpuf-registration-form input::placeholder,
.wpuf-registration-form input::placeholder {
  color: #555570 !important;
  opacity: 1;
}

/* Name field side-by-side layout */
#wpuf-registration-form .wpuf-name-field-wrap {
  display: flex;
  gap: 12px;
}

#wpuf-registration-form .wpuf-name-field-first-name,
#wpuf-registration-form .wpuf-name-field-last-name {
  flex: 1;
}

/* Submit button */
#wpuf-registration-form input[type="submit"],
#wpuf-registration-form #wp-submit,
.wpuf-registration-form input[type="submit"] {
  background: #D4AF37 !important;
  color: #0a0a0f !important;
  border: none !important;
  border-radius: 5px;
  padding: 12px 0;
  width: 100%;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition: filter .2s;
  margin-top: 6px;
}

#wpuf-registration-form input[type="submit"]:hover,
.wpuf-registration-form input[type="submit"]:hover {
  filter: brightness(1.1);
}

/* Action links (Login link below the form) */
#wpuf-registration-form .wpuf-action-links a,
.wpuf-registration-form .wpuf-action-links a {
  color: #D4AF37 !important;
  text-decoration: none;
  font-size: .85rem;
}

/* Error / success notices */
#wpuf-registration-form .wpuf-error {
  background: #2a1520;
  border-left: 3px solid #e05260;
  color: #f5a0a8 !important;
  padding: 10px 14px;
  border-radius: 4px;
  margin-bottom: 16px;
  font-size: .875rem;
}

#wpuf-registration-form .wpuf-success {
  background: #152a1e;
  border-left: 3px solid #43a047;
  color: #a5d6a7 !important;
  padding: 10px 14px;
  border-radius: 4px;
  margin-bottom: 16px;
}


/* ═══════════════════════════════════════════════════════════════════════════
   WPUF PAYMENT PAGE — dark theme
   Selectors: .wpuf-payment-page-wrap, #wpuf-payment-gateway,
              .wpuf-pack-inner, .wpuf-payment-gateways
   ═══════════════════════════════════════════════════════════════════════════ */

/* Outer wrapper */
.wpuf-payment-page-wrap {
  background: #13131a;
  border: 1px solid #2a2a3a;
  border-radius: 8px;
  padding: 32px 28px;
  max-width: 560px;
  margin: 40px auto;
  color: #d0d0d8;
  font-family: inherit;
}

/* Pack info box */
.wpuf-pack-info h3 {
  color: #f0f0f5 !important;
  font-size: 1.1rem;
  margin-bottom: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.wpuf-pack-info h3 a {
  color: #D4AF37 !important;
  font-size: .8rem;
  font-weight: 400;
  text-decoration: none;
}

.wpuf-pack-info h3 a:hover {
  text-decoration: underline;
}

.wpuf-pack-inner {
  background: #1e1e2e;
  border: 1px solid #2a2a3a;
  border-radius: 6px;
  padding: 16px 18px;
  margin-bottom: 20px;
  font-size: .95rem;
  line-height: 1.8;
  color: #c0c0d0 !important;
}

.wpuf-pack-inner div {
  color: #c0c0d0 !important;
}

.wpuf-pack-inner strong {
  color: #D4AF37 !important;
}

/* "Choose Your Payment Method" label */
#wpuf-payment-gateway > p > label[for="wpuf-payment-method"] {
  color: #d0d0d8 !important;
  font-weight: 600;
  font-size: .9rem;
  display: block;
  margin-bottom: 10px;
}

/* Gateway list — remove bullets */
.wpuf-payment-gateways,
ul.wpuf-payment-gateways {
  list-style: none !important;
  margin: 0 0 20px !important;
  padding: 0 !important;
}

.wpuf-payment-gateways li,
ul.wpuf-payment-gateways li {
  list-style: none !important;
  background: #1e1e2e;
  border: 1px solid #3a3a50;
  border-radius: 6px;
  padding: 12px 16px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: border-color .2s;
}

.wpuf-payment-gateways li:hover {
  border-color: #D4AF37;
}

.wpuf-payment-gateways li label {
  color: #d0d0d8 !important;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
}

.wpuf-payment-gateways li label input[type="radio"] {
  accent-color: #D4AF37;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* PayPal logo — constrain to a sensible size.
   Covers all selector paths from Payment.php:319-329 HTML structure:
   ul.wpuf-payment-gateways > li.wpuf-gateway-paypal > label > img  */
.wpuf-payment-gateways li img,
.wpuf-payment-gateways label img,
.wpuf-gateway-paypal img,
.wpuf-gateway-paypal label img,
#wpuf-payment-gateway img,
#wpuf-payment-gateway ul img,
#wpuf-payment-gateway li img,
#wpuf-payment-gateway label img,
.wpuf-payment-page-wrap img,
input[type="radio"] + img,
.wpuf-payment-gateways input[type="radio"] ~ img {
  max-height: 24px !important;
  max-width: 80px !important;
  width: auto !important;
  height: auto !important;
  display: inline-block !important;
  vertical-align: middle;
  object-fit: contain;
}

/* Proceed / submit button */
#wpuf-payment-gateway input[type="submit"].wpuf-btn,
#wpuf-payment-gateway input[name="wpuf_payment_submit"] {
  background: #D4AF37 !important;
  color: #0a0a0f !important;
  border: none !important;
  border-radius: 5px;
  padding: 12px 0;
  width: 100%;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition: filter .2s;
  margin-top: 4px;
}

#wpuf-payment-gateway input[type="submit"].wpuf-btn:hover {
  filter: brightness(1.1);
}

/* General text colour inside the payment form */
#wpuf-payment-gateway,
#wpuf-payment-gateway p,
#wpuf-payment-gateway div {
  color: #d0d0d8;
}
