/**
 * Polyglottika Tech Registration
 * Design tokens match frontend/tailwind.config.js (luxury reading design system).
 */

/* ========== Tokens from tailwind.config.js ========== */
.polyglottika-register-page {
  /* Base */
  --pg-base: #1E1E2E;
  --pg-mantle: #181825;
  --pg-crust: #11111B;
  /* Text */
  --pg-text: #E6E9F2;
  --pg-text-muted: #6C7086;
  --pg-text-subtle: #45475A;
  --pg-text-inverse: #1E1E2E;
  /* Champagne */
  --pg-champagne: #D4AF37;
  --pg-champagne-muted: #C7A66B;
  --pg-champagne-light: #E6C547;
  --pg-champagne-dark: #B8941F;
  /* Surface */
  --pg-surface: #313244;
  --pg-surface-hover: #45475A;
  --pg-surface-active: #585B70;
  /* Primary */
  --pg-primary: #89B4FA;
  --pg-primary-hover: #74C7EC;
  --pg-primary-active: #5B9BD5;
  /* Status */
  --pg-success: #A6E3A1;
  --pg-error: #F38BA8;
  /* Border */
  --pg-border: #45475A;
  --pg-border-light: #6C7086;
  --pg-border-focus: #89B4FA;
  /* Shadows (tailwind boxShadow) */
  --pg-shadow-focus-ring: 0 0 0 3px rgba(137, 180, 250, 0.3);
  --pg-shadow-champagne: 0 4px 14px 0 rgba(212, 175, 55, 0.25);
  --pg-shadow-reading-card: 0 2px 8px 0 rgba(0, 0, 0, 0.15), 0 1px 3px 0 rgba(0, 0, 0, 0.1);
  --pg-shadow-reading-hover: 0 4px 12px 0 rgba(0, 0, 0, 0.2), 0 2px 6px 0 rgba(0, 0, 0, 0.15);
  /* Border radius (tailwind borderRadius) */
  --pg-radius-card: 0.75rem;
  --pg-radius-input: 0.5rem;
  --pg-radius-button: 0.5rem;
  /* Typography (tailwind fontFamily) */
  --pg-font-ui: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --pg-font-heading: 'Playfair Display', Georgia, serif;
  --pg-font-reading: 'Literata', Georgia, 'Times New Roman', serif;
  /* Spacing (tailwind spacing scale) */
  --pg-2: 0.5rem;
  --pg-3: 0.75rem;
  --pg-4: 1rem;
  --pg-5: 1.25rem;
  --pg-6: 1.5rem;
  --pg-8: 2rem;
  --pg-10: 2.5rem;
  /* Sizing (tailwind maxWidth) */
  --pg-max-reading: 60ch;
  --pg-max-md: 28rem;
  /* Slightly narrower than register card for sidebar + footer */
  --pg-max-narrow: 26rem;
}

.polyglottika-register-page *,
.polyglottika-register-page *::before,
.polyglottika-register-page *::after {
  box-sizing: border-box;
}

/* ========== Page ========== */
.polyglottika-register-page {
  min-height: 100vh;
  background: var(--pg-base);
  color: var(--pg-text);
  font-family: var(--pg-font-ui);
  font-size: 1rem;
  line-height: 1.5;
  padding: var(--pg-8) var(--pg-4);
  margin: 0;
  width: 100%;
}

.pg-register-inner {
  max-width: var(--pg-max-md);
  margin: 0 auto;
}

/* ========== Header ========== */
.polyglottika-register-page .pg-register-header {
  text-align: center;
  margin-bottom: var(--pg-8);
  padding-bottom: var(--pg-6);
  border-bottom: 1px solid var(--pg-border);
}

.polyglottika-register-page .pg-register-header .pg-brand {
  font-family: var(--pg-font-heading);
  font-size: 1.875rem;
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--pg-text);
  margin: 0 0 0.35rem;
}

.polyglottika-register-page .pg-register-header .pg-brand .pg-accent {
  color: var(--pg-champagne);
}

.polyglottika-register-page .pg-register-header .pg-tagline {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--pg-text-muted);
  margin: 0;
}

/* ========== Card ========== */
.polyglottika-register-page .pg-register-card {
  background: var(--pg-surface);
  border: 1px solid var(--pg-border);
  border-radius: var(--pg-radius-card);
  box-shadow: var(--pg-shadow-reading-card);
  padding: var(--pg-8);
  margin-bottom: var(--pg-6);
}

/* ========== Plan section ========== */
.polyglottika-register-page .pg-plan-section {
  margin-bottom: var(--pg-8);
}

.polyglottika-register-page .pg-plan-heading {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--pg-text-muted);
  margin: 0 0 var(--pg-4);
}

.polyglottika-register-page .pg-plan-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--pg-4);
}

@media (max-width: 475px) {
  .polyglottika-register-page .pg-plan-cards {
    grid-template-columns: 1fr;
  }
}

.polyglottika-register-page .pg-plan-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  padding: var(--pg-4) var(--pg-3);
  font-family: inherit;
  font-size: 0.9375rem;
  color: var(--pg-text);
  background: var(--pg-mantle);
  border: 2px solid var(--pg-border);
  border-radius: var(--pg-radius-input);
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
  text-align: center;
}

.polyglottika-register-page .pg-plan-card:hover {
  background: var(--pg-surface-hover);
  border-color: var(--pg-text-subtle);
  box-shadow: var(--pg-shadow-reading-hover);
}

.polyglottika-register-page .pg-plan-card.pg-plan-selected {
  border-color: var(--pg-champagne);
  background: rgba(212, 175, 55, 0.12);
  box-shadow: 0 0 0 1px var(--pg-champagne), var(--pg-shadow-champagne);
}

.polyglottika-register-page .pg-plan-card .pg-plan-name {
  font-weight: 600;
  color: var(--pg-text);
}

.polyglottika-register-page .pg-plan-card .pg-plan-price {
  font-weight: 700;
  color: var(--pg-champagne);
  font-size: 1rem;
}

.polyglottika-register-page .pg-plan-card .pg-plan-period {
  font-weight: 400;
  font-size: 0.75rem;
  color: var(--pg-text-muted);
}

/* Hide s2Member plan dropdown and description; we use cards */
.polyglottika-register-page .pg-form-wrap #s2member-pro-stripe-registration-form-options-section,
.polyglottika-register-page .pg-form-wrap #s2member-pro-stripe-registration-form-description-section {
  display: none !important;
}

/* ========== Form layout ========== */
.polyglottika-register-page .pg-form-wrap form {
  margin: 0;
  padding: 0;
}

.polyglottika-register-page .pg-form-wrap fieldset {
  border: none;
  margin: 0;
  padding: 0;
}

.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-section,
.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-registration-form-section {
  margin: 0 0 var(--pg-6);
  padding: 0;
}

.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-section:last-child,
.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-registration-form-section:last-child {
  margin-bottom: 0;
}

.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-section-title,
.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-registration-form-section-title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--pg-text-muted);
  margin: 0 0 var(--pg-4);
}

.polyglottika-register-page .pg-form-wrap #s2member-pro-stripe-registration-form-registration-section {
  display: grid;
  gap: var(--pg-4);
}

.polyglottika-register-page .pg-form-wrap #s2member-pro-stripe-registration-form-registration-section .s2member-pro-stripe-form-div {
  margin: 0;
}

.polyglottika-register-page .pg-form-wrap #s2member-pro-stripe-registration-form-registration-section .s2member-pro-stripe-registration-form-section-title {
  grid-column: 1 / -1;
}

@media (min-width: 475px) {
  .polyglottika-register-page .pg-form-wrap #s2member-pro-stripe-registration-form-registration-section {
    grid-template-columns: 1fr 1fr;
  }
  .polyglottika-register-page .pg-form-wrap #s2member-pro-stripe-registration-form-email-div,
  .polyglottika-register-page .pg-form-wrap #s2member-pro-stripe-registration-form-username-div,
  .polyglottika-register-page .pg-form-wrap #s2member-pro-stripe-registration-form-password-div {
    grid-column: 1 / -1;
  }
}

.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-div {
  clear: none;
}

/* ========== Labels & inputs ========== */
.polyglottika-register-page .pg-form-wrap label {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--pg-text);
  margin-bottom: 0.375rem;
}

.polyglottika-register-page .pg-form-wrap label span {
  display: block;
}

.polyglottika-register-page .pg-form-wrap input[type="text"],
.polyglottika-register-page .pg-form-wrap input[type="email"],
.polyglottika-register-page .pg-form-wrap input[type="password"] {
  width: 100%;
  padding: 0.625rem 0.75rem;
  font-size: 0.9375rem;
  font-family: inherit;
  color: var(--pg-text);
  background: var(--pg-mantle);
  border: 1px solid var(--pg-border);
  border-radius: var(--pg-radius-input);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.polyglottika-register-page .pg-form-wrap input[type="text"]:focus,
.polyglottika-register-page .pg-form-wrap input[type="email"]:focus,
.polyglottika-register-page .pg-form-wrap input[type="password"]:focus {
  outline: none;
  border-color: var(--pg-border-focus);
  box-shadow: var(--pg-shadow-focus-ring);
}

.polyglottika-register-page .pg-form-wrap input::placeholder {
  color: var(--pg-text-subtle);
}

.polyglottika-register-page .pg-form-wrap #s2member-pro-stripe-registration-form-password-div input[type="password"] {
  margin-bottom: var(--pg-2);
}

.polyglottika-register-page .pg-form-wrap #s2member-pro-stripe-registration-form-password-div input[type="password"]:last-of-type {
  margin-bottom: 0.25rem;
}

.polyglottika-register-page .pg-form-wrap .ws-plugin--s2member-password-strength,
.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-password-strength {
  font-size: 0.75rem;
  color: var(--pg-text-muted);
  margin-top: 0.25rem;
  font-style: normal;
}

.polyglottika-register-page .pg-form-wrap select {
  width: 100%;
  padding: 0.625rem 0.75rem;
  font-size: 0.9375rem;
  font-family: inherit;
  color: var(--pg-text);
  background: var(--pg-mantle);
  border: 1px solid var(--pg-border);
  border-radius: var(--pg-radius-input);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236C7086' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  padding-right: 2rem;
}

.polyglottika-register-page .pg-form-wrap select:focus {
  outline: none;
  border-color: var(--pg-border-focus);
  box-shadow: var(--pg-shadow-focus-ring);
}

.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-custom-fields-section .s2member-pro-stripe-form-div,
.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-billing-method-section .s2member-pro-stripe-form-div,
.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-billing-address-section .s2member-pro-stripe-form-div {
  margin-bottom: var(--pg-4);
}

.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-captcha-section {
  margin-bottom: var(--pg-6);
}

.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-submission-section .s2member-pro-stripe-form-section-title {
  margin-bottom: var(--pg-4);
}

/* ========== Response messages ========== */
.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-response-section {
  margin-bottom: var(--pg-6);
}

.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-response-error {
  padding: var(--pg-3) var(--pg-4);
  font-size: 0.875rem;
  color: var(--pg-error);
  background: rgba(243, 139, 168, 0.1);
  border: 1px solid rgba(243, 139, 168, 0.3);
  border-radius: var(--pg-radius-input);
}

.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-response-error a {
  color: var(--pg-primary);
  text-decoration: underline;
}

.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-response-info {
  padding: var(--pg-3) var(--pg-4);
  font-size: 0.875rem;
  color: var(--pg-success);
  background: rgba(166, 227, 161, 0.1);
  border: 1px solid rgba(166, 227, 161, 0.25);
  border-radius: var(--pg-radius-input);
}

/* ========== Stripe element ========== */
.polyglottika-register-page .pg-form-wrap .StripeElement,
.polyglottika-register-page .pg-form-wrap [data-s2member-pro-stripe-form] iframe {
  background: var(--pg-mantle) !important;
  padding: 0.625rem 0.75rem;
  border: 1px solid var(--pg-border);
  border-radius: var(--pg-radius-input);
}

/* ========== Submit button (champagne CTA) ========== */
.polyglottika-register-page .pg-form-wrap input[type="submit"],
.polyglottika-register-page .pg-form-wrap button[type="submit"],
.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-registration-submit {
  display: block;
  width: 100%;
  padding: 0.75rem 1.25rem;
  font-size: 0.9375rem;
  font-weight: 600;
  font-family: inherit;
  color: var(--pg-text-inverse);
  background: var(--pg-champagne);
  border: none;
  border-radius: var(--pg-radius-button);
  cursor: pointer;
  box-shadow: var(--pg-shadow-champagne);
  transition: background 0.2s ease, box-shadow 0.2s ease;
  margin-top: var(--pg-2);
}

.polyglottika-register-page .pg-form-wrap input[type="submit"]:hover,
.polyglottika-register-page .pg-form-wrap button[type="submit"]:hover,
.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-registration-submit:hover {
  background: var(--pg-champagne-light);
  box-shadow: 0 4px 14px 0 rgba(212, 175, 55, 0.35);
}

.polyglottika-register-page .pg-form-wrap input[type="submit"]:focus,
.polyglottika-register-page .pg-form-wrap button[type="submit"]:focus,
.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-registration-submit:focus {
  outline: none;
  box-shadow: var(--pg-shadow-focus-ring);
}

/* ========== Checkbox ========== */
.polyglottika-register-page .pg-form-wrap input[type="checkbox"] {
  margin-right: var(--pg-2);
  accent-color: var(--pg-champagne);
}

.polyglottika-register-page .pg-form-wrap .s2member-pro-stripe-form-custom-reg-field-opt-in-label {
  font-size: 0.875rem;
  color: var(--pg-text-muted);
}

/* ========== Links ========== */
.polyglottika-register-page .pg-form-wrap a,
.polyglottika-register-page .pg-register-footer a {
  color: var(--pg-primary);
  text-decoration: none;
}

.polyglottika-register-page .pg-form-wrap a:hover,
.polyglottika-register-page .pg-register-footer a:hover {
  color: var(--pg-primary-hover);
  text-decoration: underline;
}

/* ========== Footer ========== */
.polyglottika-register-page .pg-register-footer {
  text-align: center;
  font-size: 0.8125rem;
  color: var(--pg-text-muted);
  margin: 0;
}

.polyglottika-register-page .pg-register-footer a {
  color: var(--pg-primary);
}

/* ========== Sidebar + footer: same width, slightly smaller than register card ========== */
/* When this page contains the register shortcode, constrain search card and everything below. */
body:has(.polyglottika-register-page) {
  --pg-max-narrow: 26rem;
}

body:has(.polyglottika-register-page) #secondary.widget-area {
  max-width: var(--pg-max-narrow);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  padding-left: 1rem;
  padding-right: 1rem;
  box-sizing: border-box;
}

body:has(.polyglottika-register-page) .site-footer .container {
  max-width: var(--pg-max-narrow);
}
