/* ============================================================
   NEUROMYNDS — Custom Subscription Styles v1.0.3
   Selectors verified from live DOM inspection Feb 2026
   ============================================================ */

/* ── VARIABLES ─────────────────────────────────────────────── */
:root {
  --nm-terracotta:    #9A4329;
  --nm-terracotta-dk: #7a3320;
  --nm-dark:          #0A232B;
  --nm-cream:         #FBF7EF;
  --nm-sand:          #F2E8DC;
  --nm-teal:          #3E6B5E;
  --nm-teal-lt:       #e8f2ef;
  --nm-muted:         #7a6a62;
  --nm-radius:        14px;
  --nm-radius-sm:     8px;
  --nm-shadow:        0 8px 40px rgba(10,35,43,0.12);
}


#nm-step-1 {
    max-width: 600px;
    margin: 0 auto;
}

.rcp_form .rcp_user_fieldset input:not([type=checkbox]):not([type=submit]) {
    max-width: none!important;
}

.rcp_registration_total_details tr {
    width: 100%!important;
}

.rcp_form #rcp_auto_renew_wrap {
    margin-top: 0!important;
}

#rcp_submit_wrap input[type="submit"], #rcp_submit_wrap #rcp_submit {
    margin: 0!important;
}

/* ══════════════════════════════════════════════════════════════
   1. RESTRICTED CONTENT — .rcp_restricted
   ══════════════════════════════════════════════════════════════ */

.rcp_restricted {
  position: relative;
  background: var(--nm-cream);
  border-radius: var(--nm-radius);
  overflow: hidden;
  padding: 0;
  margin: 20px 0 40px;
  box-shadow: var(--nm-shadow);
}
.rcp_restricted::before {
  content: '';
  display: block;
  height: 5px;
  background: linear-gradient(90deg, var(--nm-terracotta), var(--nm-teal));
}
.rcp_restricted > p { display: none; }

.nm-restricted-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 768px) {
  .nm-restricted-inner { grid-template-columns: 1fr; }
}

.nm-restricted-preview {
  background: linear-gradient(145deg, var(--nm-terracotta) 0%, #6b2d1a 100%);
  padding: 44px 36px;
  display: flex; flex-direction: column; justify-content: center;
  position: relative; overflow: hidden;
}
.nm-restricted-preview::after {
  content: '';
  position: absolute; bottom: -60px; right: -40px;
  width: 200px; height: 200px;
  background: rgba(255,255,255,0.05); border-radius: 50%;
  pointer-events: none;
}
.nm-lock-icon {
  width: 52px; height: 52px;
  background: rgba(255,255,255,0.15); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; margin-bottom: 20px;
  border: 1px solid rgba(255,255,255,0.2);
}
.nm-restricted-preview h2 {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 26px !important; font-weight: 800 !important;
  color: #fff !important; line-height: 1.2 !important; margin: 0 0 14px !important;
}
.nm-restricted-preview > p {
  display: block !important;
  font-size: 14px; color: rgba(255,255,255,0.8); line-height: 1.65; margin: 0;
}
.nm-perks { list-style: none; padding: 0; margin: 20px 0 0; display: flex; flex-direction: column; gap: 9px; }
.nm-perks li { display: flex; align-items: center; gap: 9px; font-size: 13px; color: rgba(255,255,255,0.88); }
.nm-perks li::before { content: '✦'; color: var(--nm-sand); font-size: 10px; flex-shrink: 0; }

.nm-restricted-cta {
  background: var(--nm-cream);
  padding: 44px 36px;
  display: flex; flex-direction: column; justify-content: center;
}
.nm-eyebrow {
  font-family: 'Urbanist', sans-serif;
  font-size: 10px; font-weight: 700; letter-spacing: 2.5px;
  text-transform: uppercase; color: var(--nm-teal); margin-bottom: 10px; display: block;
}
.nm-restricted-cta h3 {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 22px !important; font-weight: 800 !important;
  color: var(--nm-dark) !important; margin: 0 0 10px !important; line-height: 1.25 !important;
}
.nm-restricted-cta > p {
  font-size: 14px; color: var(--nm-muted); line-height: 1.65; margin: 0 0 24px;
}
.nm-btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--nm-terracotta); color: var(--nm-cream) !important;
  font-family: 'Urbanist', sans-serif; font-size: 15px; font-weight: 700;
  padding: 13px 26px; border-radius: 50px; text-decoration: none !important;
  border: none; cursor: pointer; width: fit-content;
  box-shadow: 0 4px 16px rgba(154,67,41,0.28);
  transition: background 0.2s, transform 0.15s;
}
.nm-btn-primary:hover { background: var(--nm-terracotta-dk); transform: translateY(-1px); }
.nm-plan-chips { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; }
.nm-chip { background: var(--nm-sand); border-radius: 50px; padding: 5px 12px; font-size: 12px; font-weight: 600; color: var(--nm-dark); }
.nm-login-hint { margin-top: 14px !important; font-size: 13px; color: var(--nm-muted); }
.nm-login-hint a { color: var(--nm-terracotta); font-weight: 600; text-decoration: underline; }


/* ══════════════════════════════════════════════════════════════
   2. ALL RCP FORMS (.rcp_form)
   IDs found: #rcp_registration_form, #rcp_change_membership_form,
              #rcp_update_card_form, #rcp_profile_editor_form
   All share class .rcp_form
   ══════════════════════════════════════════════════════════════ */

/* Form card — full width of content area */
.rcp_form {
  background: var(--nm-cream) !important;
  border-radius: var(--nm-radius) !important;
  padding: 40px 48px !important;
  box-shadow: var(--nm-shadow) !important;
  border: 1px solid rgba(154,67,41,0.07) !important;
  max-width: 100% !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
@media (max-width: 640px) {
  .rcp_form { padding: 24px 18px !important; }
}

/* Page title — scoped to pages containing RCP forms or NM blocks */
.rcp_form ~ h1,
.entry-content:has(.rcp_form) h1,
.entry-content:has(.rcp_restricted) h1 {
  font-family: 'Urbanist', sans-serif !important;
  font-size: clamp(28px, 4vw, 42px) !important;
  font-weight: 900 !important;
  color: var(--nm-dark) !important;
  letter-spacing: -0.5px !important;
  margin-bottom: 24px !important;
}

/* Log-in / info notice (first p in form) */
.rcp_form > p:first-of-type:not(#rcp_submit_wrap) {
  background: var(--nm-teal-lt) !important;
  border-left: 3px solid var(--nm-teal) !important;
  border-radius: 0 var(--nm-radius-sm) var(--nm-radius-sm) 0 !important;
  padding: 10px 14px !important;
  font-size: 14px !important; color: var(--nm-teal) !important; font-weight: 500 !important;
  margin-bottom: 24px !important;
}
.rcp_form > p:first-of-type:not(#rcp_submit_wrap) a { color: var(--nm-teal) !important; font-weight: 700 !important; }

/* Submit wrap — centred, no infobox styles */
#rcp_submit_wrap {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  text-align: center !important;
  margin-top: 28px !important;
}
#rcp_submit_wrap .rcp-button,
#rcp_submit_wrap input[type="submit"] {
  width: auto !important;
  min-width: 220px !important;
  display: inline-block !important;
  margin: 0 auto !important;
}

/* All labels */
.rcp_form label {
  font-family: 'Inter', sans-serif !important;
  font-size: 11px !important; font-weight: 600 !important;
  letter-spacing: 0.5px !important; text-transform: uppercase !important;
  color: var(--nm-muted) !important; display: block !important;
  margin-bottom: 5px !important; margin-top: 0 !important;
}

/* Text / email / password inputs */
.rcp_form input[type="text"],
.rcp_form input[type="email"],
.rcp_form input[type="password"] {
  width: 100% !important; background: #fff !important;
  border: 1.5px solid rgba(10,35,43,0.15) !important;
  border-radius: var(--nm-radius-sm) !important;
  padding: 11px 15px !important;
  font-family: 'Inter', sans-serif !important; font-size: 15px !important;
  color: var(--nm-dark) !important; outline: none !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  box-sizing: border-box !important;
}
.rcp_form input[type="text"]:focus,
.rcp_form input[type="email"]:focus,
.rcp_form input[type="password"]:focus {
  border-color: var(--nm-terracotta) !important;
  box-shadow: 0 0 0 3px rgba(154,67,41,0.11) !important;
}

/* Select inputs (e.g. Display Name) */
.rcp_form select {
  width: 100% !important; background: #fff !important;
  border: 1.5px solid rgba(10,35,43,0.15) !important;
  border-radius: var(--nm-radius-sm) !important;
  padding: 11px 15px !important;
  font-family: 'Inter', sans-serif !important; font-size: 15px !important;
  color: var(--nm-dark) !important; outline: none !important;
  box-sizing: border-box !important;
}

/* Section heading — "Choose your membership level" etc */
.rcp_form > p > strong:only-child,
.rcp_form > p:has(> strong:only-child) {
  display: block !important;
  font-family: 'Urbanist', sans-serif !important;
  font-size: 10px !important; font-weight: 700 !important;
  letter-spacing: 2px !important; text-transform: uppercase !important;
  color: var(--nm-muted) !important;
  border-bottom: 1px solid rgba(10,35,43,0.1) !important;
  padding-bottom: 8px !important; margin: 28px 0 14px !important;
}


/* ── LEVEL CARDS ────────────────────────────────────────────── */

/* The UL containing levels (no class) */
.rcp_form ul:has(> .rcp_subscription_level) {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
  gap: 12px !important;
  list-style: none !important;
  padding: 0 !important; margin: 0 0 24px !important;
}

/* Each level list item */
.rcp_subscription_level {
  background: #fff !important;
  border: 2px solid rgba(10,35,43,0.12) !important;
  border-radius: var(--nm-radius) !important;
  padding: 0 !important; margin: 0 !important;
  position: relative !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  cursor: pointer !important;
}
.rcp_subscription_level:hover {
  border-color: var(--nm-terracotta) !important;
  box-shadow: 0 4px 16px rgba(154,67,41,0.1) !important;
}

/* Hide native radio */
.rcp_subscription_level input[type="radio"] {
  position: absolute !important;
  opacity: 0 !important; width: 0 !important; height: 0 !important;
  pointer-events: none !important;
}

/* Label = full card face */
.rcp_subscription_level label {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  padding: 20px 20px 18px !important;
  cursor: pointer !important;
  text-transform: none !important; letter-spacing: 0 !important;
  font-family: 'Urbanist', sans-serif !important;
  font-size: 15px !important; font-weight: 700 !important;
  color: var(--nm-dark) !important;
  margin: 0 !important; line-height: 1.3 !important;
}

/* Level name */
.rcp_subscription_level .rcp_subscription_level_name {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 17px !important; font-weight: 800 !important;
  color: var(--nm-dark) !important;
}

/* Price */
.rcp_subscription_level .rcp_price {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 22px !important; font-weight: 900 !important;
  color: var(--nm-terracotta) !important;
}

/* Separator — hide the dashes */
.rcp_subscription_level .rcp_separator { display: none !important; }

/* Duration */
.rcp_subscription_level .rcp_level_duration {
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important; font-weight: 500 !important;
  color: var(--nm-muted) !important;
}

/* Rich text inside level descriptions */
.rcp_subscription_level .rcp_level_description,
.rcp_subscription_level .rcp_level_description * {
  text-decoration: none !important;
  border-bottom: none !important;
  background: transparent !important;
}

.rcp_subscription_level .rcp_level_description {
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  line-height: 1.55 !important;
  color: var(--nm-muted) !important;
  margin-top: 10px !important;
  padding: 0 !important;
  border: none !important;
}

.rcp_subscription_level .rcp_level_description p {
  margin: 0 0 0.6em !important;
  padding: 0 !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  line-height: 1.55 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: var(--nm-muted) !important;
  border: none !important;
  display: block !important;
}
.rcp_subscription_level .rcp_level_description p:last-child {
  margin-bottom: 0 !important;
}

/* KEY: explicitly reset <strong> back to normal bold body text */
.rcp_subscription_level .rcp_level_description strong,
.rcp_subscription_level .rcp_level_description b {
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: var(--nm-dark) !important;
  border: none !important;
  display: inline !important;
  padding: 0 !important;
  margin: 0 !important;
}

.rcp_subscription_level .rcp_level_description em,
.rcp_subscription_level .rcp_level_description i {
  font-style: italic !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.rcp_subscription_level .rcp_level_description ul,
.rcp_subscription_level .rcp_level_description ol {
  margin: 6px 0 !important;
  padding-left: 22px !important;
  display: block !important;
}

.rcp_subscription_level .rcp_level_description ul li {
  list-style-type: disc !important;
  list-style-position: outside !important;
  display: list-item !important;
  margin: 2px 0 !important;
  padding: 0 !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: var(--nm-muted) !important;
}

.rcp_subscription_level .rcp_level_description ol li {
  list-style-type: decimal !important;
  list-style-position: outside !important;
  display: list-item !important;
  margin: 2px 0 !important;
  padding: 0 !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: var(--nm-muted) !important;
}

/* Kill WoodMart's ::before bullets if any */
.rcp_subscription_level .rcp_level_description li::before,
.rcp_subscription_level .rcp_level_description li::marker {
  content: none;
}
.rcp_subscription_level .rcp_level_description ul li::marker {
  content: "•  ";
  color: var(--nm-muted);
}

.rcp_subscription_level .rcp_level_description a {
  color: var(--nm-terracotta) !important;
  border-bottom: 1px dotted currentColor !important;
}
.rcp_subscription_level .rcp_level_description a:hover {
  border-bottom-style: solid !important;
}

/* Selected state — added via JS (.nm-selected on li) */
.rcp_subscription_level.nm-selected {
  border-color: var(--nm-terracotta) !important;
  background: #fff8f5 !important;
  box-shadow: 0 4px 16px rgba(154,67,41,0.14) !important;
}
.rcp_subscription_level.nm-selected::after {
  content: '✓';
  position: absolute; top: 12px; right: 13px;
  width: 22px; height: 22px;
  background: var(--nm-terracotta); color: #fff;
  border-radius: 50%; font-size: 12px; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
}


/* ── SUBSCRIPTION SUMMARY TABLE ─────────────────────────────── */

.rcp_registration_total_details {
  width: 100% !important;
  border-collapse: collapse !important;
  background: var(--nm-sand) !important;
  border-radius: var(--nm-radius) !important;
  overflow: hidden !important;
  margin: 24px 0 !important;
  border: none !important;
  /* border-radius on table needs overflow:hidden on a wrapper — add via display:block workaround */
  display: table !important;
}

/* Wrap table in a div via outline trick */
.rcp_registration_total_details {
  box-shadow: 0 0 0 1px rgba(10,35,43,0.06) !important;
  border-radius: var(--nm-radius) !important;
  -webkit-mask-image: -webkit-radial-gradient(white, black); /* force border-radius on table */
}

.rcp_registration_total_details caption {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 10px !important; font-weight: 700 !important;
  letter-spacing: 2px !important; text-transform: uppercase !important;
  color: var(--nm-muted) !important;
  text-align: left !important;
  padding: 18px 22px 10px !important;
  caption-side: top !important;
  background: var(--nm-sand) !important;
}

.rcp_registration_total_details th,
.rcp_registration_total_details td {
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  padding: 11px 22px !important;
  border: none !important;
  border-bottom: 1px solid rgba(10,35,43,0.07) !important;
  color: var(--nm-dark) !important;
  background: transparent !important;
  text-align: left !important;
}

/* Right-align values */
.rcp_registration_total_details td:last-child,
.rcp_registration_total_details th:last-child {
  text-align: right !important;
  font-weight: 600 !important;
}

/* Section sub-headers (Discounts and Fees etc) */
.rcp_registration_total_details th[colspan],
.rcp_registration_total_details .rcp-table-section-header td,
.rcp_registration_total_details tr th:only-child {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 10px !important; font-weight: 700 !important;
  letter-spacing: 1.5px !important; text-transform: uppercase !important;
  color: var(--nm-muted) !important;
  background: rgba(10,35,43,0.04) !important;
  padding-top: 14px !important; padding-bottom: 6px !important;
}

.rcp_registration_total_details tr:last-child td,
.rcp_registration_total_details tr:last-child th {
  border-bottom: none !important;
}

/* Bold total row */
.rcp_registration_total_details tr:has(td:first-child:contains("Total Today")) td {
  font-weight: 700 !important; font-size: 15px !important;
}


/* ── STRIPE CARD ─────────────────────────────────────────────── */
.StripeElement, .rcp-gateway-stripe-card-wrap {
  background: #fff !important;
  border: 1.5px solid rgba(10,35,43,0.15) !important;
  border-radius: var(--nm-radius-sm) !important;
  padding: 13px 15px !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
}
.StripeElement--focus {
  border-color: var(--nm-terracotta) !important;
  box-shadow: 0 0 0 3px rgba(154,67,41,0.11) !important;
}


/* ── SAVED PAYMENT METHOD RADIO LIST ────────────────────────── */
.rcp-gateway-saved-payment-methods {
  list-style: none !important;
  padding: 0 !important;
  margin: 16px 0 8px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

/* Each saved card row — styled as a selectable card */
.rcp-gateway-saved-payment-methods > li {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 14px 18px !important;
  border-radius: var(--nm-radius-sm) !important;
  border: 1.5px solid rgba(10,35,43,0.12) !important;
  background: #fff !important;
  cursor: pointer !important;
  transition: border-color 0.18s, box-shadow 0.18s !important;
}
.rcp-gateway-saved-payment-methods > li:has(input:checked) {
  border-color: var(--nm-terracotta) !important;
  background: #fff8f5 !important;
  box-shadow: 0 0 0 3px rgba(154,67,41,0.09) !important;
}
.rcp-gateway-saved-payment-methods > li:hover:not(:has(input:checked)) {
  border-color: rgba(10,35,43,0.25) !important;
}

/* Hide the native radio — we style the whole row */
.rcp-gateway-saved-payment-methods input[type="radio"] {
  accent-color: var(--nm-terracotta) !important;
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
  cursor: pointer !important;
}

/* Label wraps all the spans — make it flex */
.rcp-gateway-saved-payment-methods label {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  flex-wrap: wrap !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--nm-dark) !important;
  margin: 0 !important;
  cursor: pointer !important;
  flex: 1 !important;
}

/* Card brand (Visa / Mastercard etc) */
.rcp-gateway-saved-card-brand {
  font-family: 'Urbanist', sans-serif !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  background: var(--nm-dark) !important;
  color: #fff !important;
  padding: 2px 8px !important;
  border-radius: 4px !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
}

/* Separator dashes — fade them out */
.rcp-gateway-saved-payment-method-sep {
  color: rgba(10,35,43,0.25) !important;
  font-size: 11px !important;
}

/* Ending label */
.rcp-gateway-saved-card-ending-label {
  color: var(--nm-muted) !important;
  font-size: 13px !important;
}

/* Last 4 digits */
.rcp-gateway-saved-card-last-4 {
  font-weight: 700 !important;
  font-size: 15px !important;
  letter-spacing: 1px !important;
  color: var(--nm-dark) !important;
}

/* Expiry */
.rcp-gateway-saved-card-expires-label {
  color: var(--nm-muted) !important;
  font-size: 12px !important;
}
.rcp-gateway-saved-card-expiration {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--nm-dark) !important;
}

/* CURRENT badge */
.rcp-gateway-saved-card-current {
  background: #e8f2ef !important;
  color: var(--nm-teal) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  padding: 2px 8px !important;
  border-radius: 50px !important;
}

/* Hide the trailing separator that comes right after the CURRENT badge */
.rcp-gateway-saved-card-current + .rcp-gateway-saved-payment-method-sep {
  display: none !important;
}

/* DELETE link — push to right, red, subtle */
.rcp-gateway-saved-card-delete {
  margin-left: auto !important;
}
.rcp-gateway-saved-card-delete a {
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  color: #c0392b !important;
  text-decoration: none !important;
  opacity: 0.55 !important;
  transition: opacity 0.15s !important;
}
.rcp-gateway-saved-card-delete a:hover {
  opacity: 1 !important;
}

/* "Add new card" row */
.rcp-gateway-add-payment-method-wrap {
  border-style: dashed !important;
}
.rcp-gateway-add-payment-method-wrap label {
  font-size: 13px !important;
  color: var(--nm-muted) !important;
  font-weight: 600 !important;
}
.rcp-gateway-add-payment-method-wrap:has(input:checked) label {
  color: var(--nm-terracotta) !important;
}

/* New card fields area */
.rcp-gateway-new-card-fields {
  margin-top: 16px !important;
  background: var(--nm-sand) !important;
  border-radius: var(--nm-radius-sm) !important;
  padding: 20px 20px 16px !important;
  border: 1.5px solid rgba(10,35,43,0.1) !important;
}
.rcp-gateway-new-card-fields .rcp_card_fieldset {
  border: none !important;
  padding: 0 !important;
  margin-bottom: 14px !important;
}
.rcp-gateway-new-card-fields legend {
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: var(--nm-muted) !important;
  margin-bottom: 8px !important;
  display: block !important;
}


/* ── TEST MODE NOTICE ────────────────────────────────────────── */
.rcp_test_mode_enabled,
.rcp-notice-wrap,
.rcp_form > div:has(> p > strong) {
  background: #fffbeb !important;
  border: 1px solid #fbbf24 !important;
  border-radius: var(--nm-radius-sm) !important;
  padding: 14px 18px !important;
  font-size: 13px !important; color: #92400e !important;
  margin: 16px 0 !important;
}
.rcp_form div:has(> p > strong) p { margin: 0 0 4px !important; }
.rcp_form div:has(> p > strong) li { color: #92400e !important; }
.rcp_form div:has(> p > strong) strong {
  font-size: 10px !important; letter-spacing: 1.5px !important; text-transform: uppercase !important;
  color: #92400e !important;
}


/* ── AUTO RENEW ──────────────────────────────────────────────── */
#rcp_auto_renew_wrap {
  display: flex !important; align-items: center !important; gap: 10px !important;
  margin: 18px 0 !important;
}
#rcp_auto_renew_wrap label {
  text-transform: none !important; letter-spacing: 0 !important;
  font-size: 14px !important; font-weight: 500 !important;
  color: var(--nm-dark) !important; margin: 0 !important;
}


/* ── SUBMIT BUTTON — all RCP forms ──────────────────────────── */
.rcp_form input[type="submit"],
.rcp_form button[type="submit"],
#rcp_submit, .rcp-button,
#rcp_profile_editor_submit {
  background: var(--nm-terracotta) !important;
  color: var(--nm-cream) !important;
  font-family: 'Urbanist', sans-serif !important;
  font-size: 16px !important; font-weight: 700 !important;
  border: none !important; border-radius: 50px !important;
  padding: 15px 40px !important; cursor: pointer !important;
  width: 100% !important; margin-top: 24px !important;
  box-shadow: 0 4px 16px rgba(154,67,41,0.28) !important;
  transition: background 0.2s, transform 0.15s !important;
  letter-spacing: 0.3px !important; display: block !important;
  text-align: center !important;
}
.rcp_form input[type="submit"]:hover,
.rcp_form button[type="submit"]:hover,
#rcp_submit:hover, .rcp-button:hover,
#rcp_profile_editor_submit:hover {
  background: var(--nm-terracotta-dk) !important;
  transform: translateY(-2px) !important;
}


/* ── "Your Cards" heading ─────────────────────────────────────── */
.rcp_form h3 {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 18px !important; font-weight: 800 !important;
  color: var(--nm-dark) !important; margin: 0 0 12px !important;
}

/* ── PROFILE EDITOR FORM ─────────────────────────────────────── */

/* Two-column grid for First / Last name */
#rcp_profile_first_name_wrap,
#rcp_profile_last_name_wrap {
  display: inline-block !important;
  width: calc(50% - 8px) !important;
  vertical-align: top !important;
  box-sizing: border-box !important;
}
#rcp_profile_first_name_wrap {
  margin-right: 16px !important;
}

/* Fieldset — remove browser default borders, add section spacing */
#rcp_profile_editor_form fieldset {
  border: none !important;
  padding: 0 !important;
  margin: 0 0 8px !important;
}

/* Legend — styled as a section header with left accent bar */
#rcp_profile_editor_form legend {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--nm-dark) !important;
  width: 100% !important;
  padding: 0 0 12px !important;
  margin: 0 0 20px !important;
  border-bottom: 2px solid var(--nm-sand) !important;
  position: relative !important;
  display: block !important;
  box-sizing: border-box !important;
}
#rcp_profile_editor_form legend::before {
  content: '';
  position: absolute;
  left: 0; bottom: -2px;
  width: 40px; height: 2px;
  background: var(--nm-terracotta);
  border-radius: 2px;
}

/* Separator between fieldsets */
#rcp_profile_editor_form fieldset + fieldset {
  margin-top: 36px !important;
  padding-top: 8px !important;
}

/* Field <p> wrappers — consistent spacing */
#rcp_profile_editor_form p {
  margin: 0 0 18px !important;
}
#rcp_profile_editor_form p:last-of-type {
  margin-bottom: 0 !important;
}

/* Slightly larger labels for this form */
#rcp_profile_editor_form label {
  font-size: 11.5px !important;
  letter-spacing: 0.6px !important;
  margin-bottom: 6px !important;
}

/* Inputs — slightly taller for comfort */
#rcp_profile_editor_form input[type="text"],
#rcp_profile_editor_form input[type="email"],
#rcp_profile_editor_form input[type="password"] {
  padding: 13px 16px !important;
  height: 48px !important;
  background: #fff !important;
  border: 1.5px solid rgba(10,35,43,0.13) !important;
  border-radius: var(--nm-radius-sm) !important;
  font-size: 15px !important;
  box-sizing: border-box !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
}
#rcp_profile_editor_form input:focus {
  border-color: var(--nm-terracotta) !important;
  box-shadow: 0 0 0 3px rgba(154,67,41,0.10) !important;
  outline: none !important;
}

/* Select — custom styled with chevron arrow */
#rcp_profile_display_name_wrap {
  position: relative !important;
}
#rcp_profile_display_name_wrap::after {
  content: '' !important;
  position: absolute !important;
  right: 16px !important;
  bottom: 19px !important;
  width: 0 !important;
  height: 0 !important;
  border-left: 5px solid transparent !important;
  border-right: 5px solid transparent !important;
  border-top: 6px solid var(--nm-muted) !important;
  pointer-events: none !important;
}
#rcp_profile_editor_form select {
  padding: 13px 40px 13px 16px !important;
  height: 48px !important;
  background: #fff !important;
  border: 1.5px solid rgba(10,35,43,0.13) !important;
  border-radius: var(--nm-radius-sm) !important;
  font-size: 15px !important;
  font-family: 'Inter', sans-serif !important;
  color: var(--nm-dark) !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  box-sizing: border-box !important;
  cursor: pointer !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
}
#rcp_profile_editor_form select:focus {
  border-color: var(--nm-terracotta) !important;
  box-shadow: 0 0 0 3px rgba(154,67,41,0.10) !important;
  outline: none !important;
}

/* Save button — tighter, centred, not full-width */
#rcp_profile_editor_submit {
  width: auto !important;
  min-width: 200px !important;
  display: block !important;
  margin: 32px auto 0 !important;
}

@media (max-width: 560px) {
  #rcp_profile_first_name_wrap,
  #rcp_profile_last_name_wrap {
    width: 100% !important;
    display: block !important;
    margin-right: 0 !important;
  }
  #rcp_profile_editor_submit {
    width: 100% !important;
  }
}


/* ══════════════════════════════════════════════════════════════
   3. WELCOME PAGE
   Structure (WPBakery strips <a> tags but keeps div wrappers):
   .nm-welcome-page
     .nm-welcome-hero
     .nm-steps-grid  ← 15 raw children: P, DIV.nm-step-icon, H3, P, P, (×3)
     .nm-community-cta
       DIV (text)
       P  (CTA link)
   ══════════════════════════════════════════════════════════════ */

.nm-welcome-page {
  max-width: 880px;
  margin: 0 auto;
  padding: 10px 0 60px;
}

/* Hero */
.nm-welcome-hero {
  background: linear-gradient(145deg, var(--nm-terracotta) 0%, #6b2d1a 100%);
  border-radius: var(--nm-radius);
  padding: 52px 40px;
  margin-bottom: 28px;
  text-align: center;
  position: relative; overflow: hidden;
}
.nm-welcome-hero::before {
  content: ''; position: absolute; border-radius: 50%;
  background: rgba(255,255,255,0.06);
  width: 260px; height: 260px; top: -80px; right: -60px;
  pointer-events: none;
}
.nm-welcome-hero::after {
  content: ''; position: absolute; border-radius: 50%;
  background: rgba(255,255,255,0.04);
  width: 320px; height: 320px; bottom: -100px; left: -80px;
  pointer-events: none;
}

.nm-welcome-hero p:first-child {
  font-size: 40px; display: block;
  margin: 0 0 14px; position: relative;
}
.nm-welcome-hero h1 {
  font-family: 'Urbanist', sans-serif !important;
  font-size: clamp(30px, 5vw, 50px) !important;
  font-weight: 900 !important; color: #fff !important;
  margin: 0 0 12px !important; letter-spacing: -1px !important;
  position: relative;
}
.nm-welcome-hero p:not(:first-child) {
  font-size: 15px !important; color: rgba(255,255,255,0.82) !important;
  line-height: 1.65 !important; max-width: 460px; margin: 0 auto !important;
  position: relative;
}

/* ── Steps grid ─────────────────────────────────────────────── */

.nm-steps-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px !important;
  margin-bottom: 20px !important;
}

/* Each card is an <a> — reset link styles, then style as card */
.nm-steps-grid > .nm-step-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  text-decoration: none !important;
  color: var(--nm-dark) !important;
  background: var(--nm-cream) !important;
  border: 1.5px solid rgba(10,35,43,0.1) !important;
  border-radius: var(--nm-radius) !important;
  padding: 32px 24px 28px !important;
  gap: 12px !important;
  box-shadow: 0 2px 8px rgba(10,35,43,0.06) !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease !important;
}

.nm-steps-grid > .nm-step-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 24px rgba(10,35,43,0.12) !important;
  border-color: rgba(10,35,43,0.2) !important;
}

.nm-steps-grid > .nm-step-card .nm-step-icon {
  width: 60px !important;
  height: 60px !important;
  border-radius: 50% !important;
  background: var(--nm-sand) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 26px !important;
  flex-shrink: 0 !important;
  margin-bottom: 4px !important;
}

.nm-steps-grid > .nm-step-card h3 {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  color: var(--nm-dark) !important;
  margin: 0 !important;
  line-height: 1.3 !important;
}

.nm-steps-grid > .nm-step-card p {
  font-size: 13px !important;
  color: var(--nm-muted) !important;
  line-height: 1.65 !important;
  margin: 0 !important;
}

@media (max-width: 640px) {
  .nm-steps-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ── Community CTA ───────────────────────────────────────────── */
.nm-community-cta {
  background: var(--nm-teal) !important;
  border-radius: var(--nm-radius) !important;
  padding: 32px 36px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 20px !important;
  margin-top: 8px !important;
}
@media (max-width: 580px) {
  .nm-community-cta { flex-direction: column !important; text-align: center !important; }
}

.nm-community-cta > div { flex: 1; }

.nm-community-cta h3,
.nm-community-cta > div > h3 {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 20px !important; font-weight: 800 !important;
  color: #fff !important; margin: 0 0 5px !important;
}
.nm-community-cta p {
  font-size: 13px !important; color: rgba(255,255,255,0.78) !important;
  line-height: 1.5 !important; margin: 0 !important;
}

/* The "Set up profile →" link WPBakery wraps in a bare <p> */
.nm-community-cta > p {
  flex-shrink: 0 !important;
}
.nm-community-cta > p a,
.nm-community-cta a {
  display: inline-flex !important; align-items: center !important;
  background: #fff !important; color: var(--nm-teal) !important;
  font-family: 'Urbanist', sans-serif !important;
  font-size: 14px !important; font-weight: 700 !important;
  padding: 12px 22px !important; border-radius: 50px !important;
  text-decoration: none !important; white-space: nowrap !important;
  box-shadow: 0 4px 14px rgba(0,0,0,0.14) !important;
  transition: box-shadow 0.2s, transform 0.15s !important;
}
.nm-community-cta a:hover { transform: translateY(-1px) !important; box-shadow: 0 8px 22px rgba(0,0,0,0.2) !important; }

.nm-btn-white {
  display: inline-flex !important; align-items: center !important;
  background: #fff !important; color: var(--nm-teal) !important;
  font-family: 'Urbanist', sans-serif !important;
  font-size: 14px !important; font-weight: 700 !important;
  padding: 12px 22px !important; border-radius: 50px !important;
  text-decoration: none !important; white-space: nowrap !important;
  flex-shrink: 0 !important;
}


/* ══════════════════════════════════════════════════════════════
   4. REGISTRATION FORM — multi-step wizard
   Steps: 1 Your Details  2 Choose Plan  3 Confirm & Pay
   ══════════════════════════════════════════════════════════════ */

/* ── Step progress bar ───────────────────────────────────────── */
#nm-steps-bar {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
  margin: 0 0 36px;
  padding: 0;
  list-style: none;
}
.nm-step-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  position: relative;
  flex: 1;
  max-width: 160px;
}
/* Connecting line between steps */
.nm-step-item + .nm-step-item::before {
  content: '';
  position: absolute;
  left: calc(-50%);
  top: 16px;
  width: 100%;
  height: 2px;
  background: var(--nm-sand);
  z-index: 0;
  transition: background 0.3s;
}
.nm-step-item.nm-done + .nm-step-item::before {
  background: var(--nm-terracotta);
}
/* Circle */
.nm-step-circle {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid var(--nm-sand);
  background: #fff;
  color: var(--nm-muted);
  font-family: 'Urbanist', sans-serif;
  font-size: 13px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  transition: all 0.3s;
}
.nm-step-item.nm-active .nm-step-circle {
  background: var(--nm-terracotta);
  border-color: var(--nm-terracotta);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(154,67,41,0.15);
}
.nm-step-item.nm-done .nm-step-circle {
  background: var(--nm-terracotta);
  border-color: var(--nm-terracotta);
  color: #fff;
}
.nm-step-item.nm-done .nm-step-circle::after {
  content: '✓';
  font-size: 13px;
}
.nm-step-item.nm-done .nm-step-num { display: none; }
/* Label */
.nm-step-label {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3px;
  color: var(--nm-muted);
  text-align: center;
  white-space: nowrap;
  transition: color 0.3s;
}
.nm-step-item.nm-active .nm-step-label { color: var(--nm-dark); }
.nm-step-item.nm-done .nm-step-label  { color: var(--nm-terracotta); }

/* ── Step panels ─────────────────────────────────────────────── */
.nm-step-panel {
  display: none;
  animation: nmFadeIn 0.25s ease;
}
.nm-step-panel.nm-visible { display: block; }

@keyframes nmFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Step navigation buttons ─────────────────────────────────── */
#nm-step-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 24px;
  gap: 12px;
}
#nm-btn-back {
  background: none;
  border: 1.5px solid rgba(10,35,43,0.18);
  border-radius: 50px;
  padding: 12px 28px;
  font-family: 'Urbanist', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--nm-muted);
  cursor: pointer;
  transition: all 0.18s;
  display: none;
}
#nm-btn-back:hover {
  border-color: var(--nm-dark);
  color: var(--nm-dark);
}
#nm-btn-next {
  background: var(--nm-terracotta);
  border: none;
  border-radius: 50px;
  padding: 14px 36px;
  font-family: 'Urbanist', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(154,67,41,0.28);
  transition: background 0.18s, transform 0.15s;
  margin-left: auto;
}
#nm-btn-next:hover { background: var(--nm-terracotta-dk); transform: translateY(-1px); }

/* ── Step 2 — plan selector ──────────────────────────────────── */
.rcp_subscription_fieldset {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.rcp_subscription_fieldset > legend,
.rcp_subscription_message { display: none !important; }

/* Billing switch */
#nm-billing-switch-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin: 0 0 24px;
}
#nm-billing-switch-wrap .nm-period-label {
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--nm-muted);
  cursor: pointer;
  user-select: none;
  transition: color 0.2s;
}
#nm-billing-switch-wrap .nm-period-label.nm-active { color: var(--nm-dark); }
#nm-billing-toggle {
  position: relative;
  width: 44px; height: 24px;
  background: var(--nm-sand);
  border-radius: 50px;
  border: 1.5px solid rgba(10,35,43,0.15);
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
  flex-shrink: 0;
}
#nm-billing-toggle.nm-yearly { background: var(--nm-terracotta); border-color: var(--nm-terracotta); }
#nm-billing-toggle::after {
  content: '';
  position: absolute;
  top: 3px; left: 3px;
  width: 16px; height: 16px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
  transition: transform 0.2s;
}
#nm-billing-toggle.nm-yearly::after { transform: translateX(20px); }
#nm-save-badge {
  font-size: 10px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase;
  color: var(--nm-teal); background: var(--nm-teal-lt);
  padding: 2px 8px; border-radius: 50px;
  opacity: 0; transition: opacity 0.2s;
}
#nm-save-badge.nm-visible { opacity: 1; }

/* Plan grid — 3 columns on step 2 */
.rcp_form ul#rcp_subscription_levels {
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 14px !important;
}
#rcp_subscription_levels.nm-show-monthly .rcp_subscription_level[data-period="yearly"],
#rcp_subscription_levels.nm-show-yearly  .rcp_subscription_level[data-period="monthly"] {
  display: none !important;
}

/* ── Step 3 — two-column grid ────────────────────────────────── */
.nm-step3-grid {
  display: grid !important;
  grid-template-columns: 1fr 300px !important;
  grid-template-rows: auto auto !important;
  gap: 24px !important;
  align-items: start !important;
  margin-bottom: 0 !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.nm-step3-left  { min-width: 0; grid-column: 1; }
.nm-step3-right { min-width: 0; grid-column: 2; grid-row: 1 }

/* Submit wrap spans only the left column */
.nm-step3-grid > #rcp_submit_wrap {
  grid-column: 1 / -1 !important;
  grid-row: 2 !important;
}

/* ── Right column: order summary card ───────────────────────── */
#nm-order-summary {
  background: var(--nm-cream) !important;
  border: 1.5px solid rgba(10,35,43,0.09) !important;
  border-radius: var(--nm-radius) !important;
  padding: 20px 22px !important;
  box-shadow: 0 2px 12px rgba(10,35,43,0.06) !important;
  margin-bottom: 16px !important;
}
.nm-order-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-bottom: 16px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid rgba(10,35,43,0.08) !important;
}
.nm-order-label {
  font-family: 'Inter', sans-serif !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: var(--nm-muted) !important;
}
.nm-plan-change {
  font-family: 'Inter', sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--nm-teal) !important;
  cursor: pointer !important;
  text-decoration: underline !important;
}
.nm-order-plan-name {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  color: var(--nm-dark) !important;
  margin-bottom: 8px !important;
}
.nm-order-price {
  font-family: 'Urbanist', sans-serif !important;
  font-size: 30px !important;
  font-weight: 900 !important;
  color: var(--nm-terracotta) !important;
  line-height: 1.1 !important;
}
.nm-order-per {
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--nm-muted) !important;
}

/* Subscription details table — sits below the plan card */
.rcp_registration_total { margin: 0 !important; }
.rcp_registration_total_details {
  margin: 0 !important;
  background: #fff !important;
  border-radius: var(--nm-radius) !important;
  box-shadow: 0 0 0 1px rgba(10,35,43,0.07) !important;
  -webkit-mask-image: none !important;
  width: 100% !important;
  border-collapse: collapse !important;
}
.rcp_registration_total_details caption { display: none !important; }
/* thead — full-width label, no padding */
.rcp_registration_total_details thead tr { padding: 0 !important; }
.rcp_registration_total_details thead th {
  width: 100% !important;
  display: block !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: var(--nm-muted) !important;
  background: rgba(10,35,43,0.03) !important;
  padding: 12px 16px 8px !important;
  border-bottom: none !important;
}
/* tbody rows */
.rcp_registration_total_details th,
.rcp_registration_total_details td {
  padding: 10px 16px !important;
  font-size: 13px !important;
  border-bottom: none !important;
}
.rcp_registration_total_details tbody tr {
  border-top: 1px solid rgba(10,35,43,0.06) !important;
}
.rcp_registration_total_details tbody tr:first-child {
  border-top: none !important;
}
/* Last row (total) — bold */
.rcp_registration_total_details tbody tr:last-child td {
  font-weight: 700 !important;
  font-size: 14px !important;
  color: var(--nm-dark) !important;
  border-bottom: none !important;
}

/* ── Left column: payment box ────────────────────────────────── */
#rcp_gateway_extra_fields {
  background: var(--nm-sand) !important;
  border-radius: var(--nm-radius) var(--nm-radius) 0 0 !important;
  padding: 24px 24px !important;
  border: 1.5px solid rgba(10,35,43,0.08) !important;
  border-bottom: none !important;
  margin-bottom: 0 !important;
  position: relative !important;
}
#rcp_gateway_extra_fields .nm-section-label {
  font-family: 'Urbanist', sans-serif;
  font-size: 16px; font-weight: 800; color: var(--nm-dark);
  padding-bottom: 12px; margin-bottom: 20px;
  border-bottom: 2px solid rgba(10,35,43,0.1);
  display: block; position: relative;
}
#rcp_gateway_extra_fields .nm-section-label::after {
  content: ''; position: absolute; left: 0; bottom: -2px;
  width: 40px; height: 2px;
  background: var(--nm-terracotta); border-radius: 2px;
}
#rcp_gateway_extra_fields label {
  font-family: 'Inter', sans-serif !important;
  font-size: 11px !important; font-weight: 600 !important;
  letter-spacing: 0.5px !important; text-transform: uppercase !important;
  color: var(--nm-muted) !important;
  display: block !important; margin-bottom: 6px !important;
}
#rcp_gateway_extra_fields input[type="text"] {
  width: 100% !important; background: #fff !important;
  border: 1.5px solid rgba(10,35,43,0.13) !important;
  border-radius: var(--nm-radius-sm) !important;
  padding: 13px 16px !important; height: 48px !important;
  font-size: 15px !important; font-family: 'Inter', sans-serif !important;
  color: var(--nm-dark) !important; box-sizing: border-box !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  margin-bottom: 16px !important;
}
#rcp_gateway_extra_fields input[type="text"]:focus {
  border-color: var(--nm-terracotta) !important;
  box-shadow: 0 0 0 3px rgba(154,67,41,0.10) !important;
  outline: none !important;
}
/* Remove padding/border from inner Stripe card fields wrapper */
.rcp-gateway-new-card-fields {
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  margin: 0 !important;
}
#rcp-sandbox-gateway-test-cards { display: none !important; }

/* Auto-renew — fused to bottom of card payment box */
#rcp_auto_renew_wrap {
  background: var(--nm-sand) !important;
  border: 1.5px solid rgba(10,35,43,0.08) !important;
  border-top: 1px solid rgba(10,35,43,0.1) !important;
  border-radius: 0 0 var(--nm-radius) var(--nm-radius) !important;
  padding: 14px 24px !important;
  margin-bottom: 0 !important;
}

/* Submit wrap — Back left, Register & Pay right */
#rcp_submit_wrap {
  background: none !important;
  border: none !important;
  padding: 20px 0 0 !important;
  margin-top: 0 !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
#rcp_submit_wrap input[type="submit"],
#rcp_submit_wrap .rcp-button {
  width: auto !important;
  min-width: 200px !important;
  display: inline-block !important;
  font-size: 15px !important;
  padding: 13px 32px !important;
  margin-left: auto !important;
}

/* Step 3 responsive */
@media (max-width: 760px) {
  .nm-step3-grid { grid-template-columns: 1fr !important; }
  .nm-step3-right { order: -1; }
}

/* ── Step 1: User fieldset ───────────────────────────────────── */
.rcp_user_fieldset {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  max-width: 600px !important;
  /* Flex grid so rows wrap properly with no whitespace issues */
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
}
.rcp_user_fieldset legend { display: none !important; }
.rcp_login_link {
  margin-bottom: 8px !important;
  font-size: 14px !important;
  color: var(--nm-muted) !important;
  width: 100% !important;
}

/* All field <p> wrappers — reset margin (gap handles spacing) */
#rcp_registration_form .rcp_user_fieldset p {
  margin: 0 !important;
  box-sizing: border-box !important;
}

/* Username hidden (auto-filled from email) */
#rcp_user_login_wrap { display: none !important; }

/* Email — full width */
#rcp_user_email_wrap {
  width: 100% !important;
}

/* First + Last name side by side */
#rcp_user_first_wrap, #rcp_user_last_wrap {
  width: calc(50% - 8px) !important;
}

/* Password + Confirm side by side */
#rcp_password_wrap, #rcp_password_again_wrap {
  width: calc(50% - 8px) !important;
}

/* ── Combined Terms/Privacy + Newsletter checkboxes ────────── */
#nm-agree-combined-wrap {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 12px 0 0 !important;
  width: 100% !important;
}
#nm-step-1 > p:has(#rcp_mailchimp_pro_signup) {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 0 !important;
  width: 100% !important;
}
#nm-agree-combined-wrap label,
#nm-step-1 > p:has(#rcp_mailchimp_pro_signup) label {
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--nm-dark) !important;
  margin: 0 !important;
  display: inline !important;
}
#nm-agree-combined-wrap a {
  color: var(--nm-terracotta) !important;
  font-weight: 600 !important;
  text-decoration: underline !important;
}
#nm-step-1 input[type="checkbox"] {
  accent-color: var(--nm-terracotta) !important;
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
  cursor: pointer !important;
}

/* ── Validation error shake ──────────────────────────────────── */
@keyframes nmShake {
  0%,100% { transform: translateX(0); }
  20%,60% { transform: translateX(-6px); }
  40%,80% { transform: translateX(6px); }
}
.nm-error { border-color: #c0392b !important; box-shadow: 0 0 0 3px rgba(192,57,43,0.12) !important; }
.nm-shake { animation: nmShake 0.4s ease; }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 640px) {
  .rcp_form ul#rcp_subscription_levels {
    grid-template-columns: 1fr !important;
  }
  #rcp_user_first_wrap, #rcp_user_last_wrap,
  #rcp_password_wrap, #rcp_password_again_wrap {
    width: 100% !important; display: block !important; margin-right: 0 !important;
  }
  #nm-steps-bar { gap: 0; }
  .nm-step-label { font-size: 9px; }
}
/* ── Step 3 Back button (inside submit wrap) ─────────────────── */
#nm-btn-back-3 {
  background: none !important;
  border: 1.5px solid rgba(10,35,43,0.18) !important;
  border-radius: 50px !important;
  padding: 12px 28px !important;
  font-family: 'Urbanist', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--nm-muted) !important;
  cursor: pointer !important;
  transition: all 0.18s !important;
}
#nm-btn-back-3:hover {
  border-color: var(--nm-dark) !important;
  color: var(--nm-dark) !important;
}


/* ============================================================
   RCP ACCOUNT OVERVIEW — /register/your-membership/
   ============================================================ */

/* Error / notice banner */
p.rcp_error {
  background: #fff3f3!important;
  border: 1px solid #e8b4b4!important;
  border-left: 4px solid #c0392b!important;
  border-radius: 8px!important;
  padding: 14px 20px!important;
  margin: 0 20px!important;
  font-size: 0.9rem!important;
  color: #5a1a1a!important;
}

.rcp-table a button {
    padding: 0!important;
    background: transparent!important;
    display: inline-block;
    line-height: 1.2;
    margin: 0 !important;
    min-height: 0;
}

/* Section headings: Account Overview, Payment History */
#rcp-account-overview,
#rcp-payment-history {
  border-collapse: collapse;
  width: 100%;
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  margin-bottom: 40px;
}

/* Shared heading style — scoped to RCP account/restricted contexts */
.rcp-account-wrapper h2,
.entry-content:has(.rcp-account-wrapper) h2,
.entry-content:has(.rcp_restricted) h2,
.entry-content:has(.nm-welcome-page) h2 {
  font-family: 'Urbanist', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 16px;
  color: #1a1a1a;
}

/* Table header row */
#rcp-account-overview thead th,
#rcp-payment-history thead th {
  background: #f5f0eb;
  text-transform: uppercase;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  font-weight: 600;
  color: #7a6a5a;
  padding: 12px 16px;
  text-align: left;
  border-bottom: 2px solid #e8e0d8;
}

/* Table rows */
#rcp-account-overview tbody td,
#rcp-payment-history tbody td {
  padding: 14px 16px;
  border-bottom: 1px solid #ede8e0;
  vertical-align: middle;
  color: #2a2a2a;
}

/* Zebra rows */
#rcp-account-overview tbody tr:nth-child(even) td,
#rcp-payment-history tbody tr:nth-child(even) td {
  background: #faf8f5;
}

/* Status badge: Expired */
td:has(> .rcp_expired_text),
td .rcp_expired_text {
  color: #c0392b;
  font-weight: 600;
}

/* Action buttons in table */
.rcp_sub_details_update_card,
.rcp_sub_details_renew,
.rcp_sub_details_change_membership,
a.rcp_receipt_link {
  display: inline-block;
  padding: 7px 14px;
  border-radius: 6px;
  font-size: 0.8rem;
  font-weight: 600;
  font-family: 'Inter', sans-serif;
  text-decoration: none;
  margin-bottom: 6px;
  transition: opacity 0.2s;
  letter-spacing: 0.02em;
}

.rcp_sub_details_update_card {
  background: #8b4513;
  color: #fff !important;
}

.rcp_sub_details_renew {
  background: #2d6a4f;
  color: #fff !important;
}

.rcp_sub_details_change_membership {
  background: #f5f0eb;
  color: #5a3a1a !important;
  border: 1px solid #d8c8b8;
}

a.rcp_receipt_link {
  background: #f5f0eb;
  color: #5a3a1a !important;
  border: 1px solid #d8c8b8;
}

.rcp_sub_details_update_card:hover,
.rcp_sub_details_renew:hover,
.rcp_sub_details_change_membership:hover,
a.rcp_receipt_link:hover {
  opacity: 0.85;
}

/* Table wrapper max-width and breathing room */
#rcp-table-wrapper {
    width: 100%;
  margin: 0 auto;
  padding: 40px 20px;
  max-width: none!important;
}

/* ── Fix: WoodMart adds a thick border to <a> tags matching bg colour ── */
.rcp_sub_details_update_card,
.rcp_sub_details_renew,
.rcp_sub_details_change_membership,
a.rcp_receipt_link {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  /* Slightly more pill-shaped and airy */
  padding: 9px 18px !important;
  border-radius: 20px !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
  display: inline-block !important;
  margin-bottom: 6px !important;
}

/* Individual colours */
.rcp_sub_details_update_card {
  background: #7a3b10 !important;
}

.rcp_sub_details_update_card button {
    color: #fff !important;
}

.rcp_sub_details_renew {
  background: #1e5c3a !important;
}

.rcp_sub_details_renew button {
    color: #fff !important;
}

.rcp_sub_details_change_membership {
  background: #f0ebe4 !important;
  color: #4a3520 !important;
  border: 1px solid #c8b8a0 !important;
}

a.rcp_receipt_link {
  background: #f0ebe4 !important;
  color: #4a3520 !important;
  border: 1px solid #c8b8a0 !important;
}

/* Hover states */
.rcp_sub_details_update_card:hover { background: #5c2c0c !important; }
.rcp_sub_details_renew:hover { background: #164429 !important; }
.rcp_sub_details_change_membership:hover,
a.rcp_receipt_link:hover { background: #e5ddd3 !important; }

/* Fix: buttons stretch full TD width — constrain them */
.rcp_sub_details_update_card,
.rcp_sub_details_renew,
.rcp_sub_details_change_membership,
a.rcp_receipt_link {
  display: inline-block;
  width: fit-content !important;
  text-align: center !important;
  box-sizing: border-box !important;
}