/* ================================================================
   PR Login v1.3.0 — SaaS branded login for PropertyRoute
   ================================================================ */

#prl-root {
  --prl-accent:       #18b652;
  --prl-accent-dark:  #14a047;
  --prl-accent-ring:  rgba(24,182,82,.22);
  --prl-text:         #0f172a;
  --prl-text-muted:   #64748b;
  --prl-text-light:   #94a3b8;
  --prl-border:       #e2e8f0;
  --prl-card-bg:      #ffffff;
  --prl-input-bg:     #f8fafc;
  --prl-error:        #ef4444;
  --prl-error-soft:   #fef2f2;
  --prl-error-border: #fecaca;
  --prl-r:            10px;

  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
  box-sizing: border-box;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 32px 16px 40px;
  width: 100%;
  /* Use whatever background WordPress/theme sets — no override */
  background: transparent;
}

#prl-root * { box-sizing: border-box; }

/* ── Card ──────────────────────────────────────────────────────── */
#prl-root .prl-card {
  background: var(--prl-card-bg);
  border: 1px solid var(--prl-border);
  border-radius: 20px;
  box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 20px 48px rgba(0,0,0,.09);
  padding: 30px 28px 26px;
  width: 100%;
  max-width: 460px;
  animation: prl-in .38s cubic-bezier(.22,.68,0,1.12) both;
}

@keyframes prl-in {
  from { opacity:0; transform:translateY(14px) scale(.985); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}

/* ── Brand ─────────────────────────────────────────────────────── */
#prl-root .prl-brand {
  margin-bottom: 22px;
}

#prl-root .prl-logo-img {
  height: 44px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
  display: block;
}

#prl-root .prl-logo-img--fallback {
  height: 44px;
  width: auto;
}

/* ── Tabs ──────────────────────────────────────────────────────── */
#prl-root .prl-tabs {
  display: flex;
  gap: 3px;
  background: #f1f5f9;
  border: 1px solid var(--prl-border);
  border-radius: 11px;
  padding: 3px;
  margin-bottom: 18px;
}

#prl-root .prl-tab {
  flex: 1;
  padding: 7px 12px;
  border: none;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  background: transparent;
  color: var(--prl-text-muted);
  transition: all .15s;
  font-family: inherit;
}

#prl-root .prl-tab--active {
  background: #fff;
  color: var(--prl-text);
  box-shadow: 0 1px 3px rgba(0,0,0,.1);
}

/* ── Google / Nextend social ───────────────────────────────────── */
#prl-root .prl-social-wrap {
  margin-bottom: 14px;
}

/* Reset Nextend container */
#prl-root .prl-social-wrap .nsl-container,
#prl-root .prl-social-wrap .nsl-container-block,
#prl-root .prl-social-wrap .nsl-container-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
}

/* The button itself */
#prl-root .prl-social-wrap .nsl-button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 44px !important;
  padding: 0 16px !important;
  margin: 0 !important;
  border: 1.5px solid var(--prl-border) !important;
  border-radius: var(--prl-r) !important;
  background: #fff !important;
  box-shadow: none !important;
  font-family: inherit !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--prl-text) !important;
  cursor: pointer !important;
  transition: border-color .15s, box-shadow .15s, background .15s !important;
  text-decoration: none !important;
  position: relative !important;
}

#prl-root .prl-social-wrap .nsl-button:hover {
  border-color: #c0ccd8 !important;
  background: #f8fafc !important;
  box-shadow: 0 2px 6px rgba(0,0,0,.07) !important;
  color: var(--prl-text) !important;
  text-decoration: none !important;
}

/* Nextend inner layout — icon left, text centered */
#prl-root .prl-social-wrap .nsl-button-default-icon,
#prl-root .prl-social-wrap .nsl-button-svg-container {
  background: none !important;
  border: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 20px !important;
  height: 20px !important;
  flex-shrink: 0 !important;
  margin-right: 10px !important;
  padding: 0 !important;
}

/* Make sure SVG/img inside icon container is visible and sized */
#prl-root .prl-social-wrap .nsl-button-default-icon img,
#prl-root .prl-social-wrap .nsl-button-default-icon svg,
#prl-root .prl-social-wrap .nsl-button-svg-container img,
#prl-root .prl-social-wrap .nsl-button-svg-container svg {
  width: 18px !important;
  height: 18px !important;
  display: block !important;
  object-fit: contain !important;
}

#prl-root .prl-social-wrap .nsl-button-label-container {
  flex: 1 !important;
  text-align: center !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--prl-text) !important;
}

/* Remove any Nextend colored left strip */
#prl-root .prl-social-wrap .nsl-button::before { display: none !important; }
#prl-root .prl-social-wrap .nsl-button-facebook { border-color: var(--prl-border) !important; }

/* ── Divider ───────────────────────────────────────────────────── */
#prl-root .prl-divider {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  color: var(--prl-text-light);
  font-size: 12px;
}

#prl-root .prl-divider::before,
#prl-root .prl-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--prl-border);
}

/* ── Fields ────────────────────────────────────────────────────── */
#prl-root .prl-field { margin-bottom: 13px; }

#prl-root .prl-label-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

#prl-root .prl-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--prl-text);
  margin-bottom: 6px;
}

#prl-root .prl-label-row .prl-label { margin-bottom: 0; }

#prl-root .prl-forgot {
  font-size: 12px;
  color: var(--prl-accent);
  text-decoration: none;
  font-weight: 500;
}
#prl-root .prl-forgot:hover { text-decoration: underline; }

#prl-root .prl-input-wrap { position: relative; }

#prl-root .prl-input {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px solid var(--prl-border);
  border-radius: var(--prl-r);
  background: var(--prl-input-bg);
  font-size: 16px;
  color: var(--prl-text);
  font-family: inherit;
  transition: border-color .15s, box-shadow .15s;
  outline: none;
  display: block;
}

#prl-root .prl-input-wrap .prl-input { padding-right: 42px; }

#prl-root .prl-input:focus {
  border-color: var(--prl-accent);
  box-shadow: 0 0 0 3px var(--prl-accent-ring);
  background: #fff;
}

#prl-root .prl-input::placeholder { color: #c8d4e0; }
#prl-root .prl-input--error { border-color: var(--prl-error) !important; box-shadow: 0 0 0 3px rgba(239,68,68,.1); }

/* Eye toggle */
#prl-root .prl-eye {
  position: absolute;
  right: 11px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  padding: 3px;
  cursor: pointer;
  color: var(--prl-text-light);
  display: flex;
  align-items: center;
  line-height: 0;
}
#prl-root .prl-eye:hover { color: var(--prl-text-muted); }

/* Strength */
#prl-root .prl-strength { margin-top: 7px; display: flex; align-items: center; gap: 10px; }
#prl-root .prl-strength-bar { flex: 1; height: 3px; background: var(--prl-border); border-radius: 99px; overflow: hidden; }
#prl-root .prl-strength-fill { height: 100%; border-radius: 99px; width: 0; transition: width .3s, background .3s; }
#prl-root .prl-strength-label { font-size: 11px; font-weight: 600; min-width: 58px; text-align: right; }

/* Remember */
#prl-root .prl-remember {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  cursor: pointer;
  font-size: 13px;
  color: var(--prl-text-muted);
  user-select: none;
}
#prl-root .prl-remember input[type="checkbox"] {
  width: 15px;
  height: 15px;
  accent-color: var(--prl-accent);
  cursor: pointer;
  flex-shrink: 0;
}

/* Alert */
#prl-root .prl-alert {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  padding: 10px 12px;
  border-radius: var(--prl-r);
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 13px;
  line-height: 1.5;
}
#prl-root .prl-alert--error {
  background: var(--prl-error-soft);
  border: 1px solid var(--prl-error-border);
  color: #dc2626;
}
#prl-root .prl-alert svg { flex-shrink: 0; margin-top: 1px; }

/* Submit */
#prl-root .prl-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  padding: 12px;
  background: var(--prl-accent);
  color: #fff;
  border: none;
  border-radius: var(--prl-r);
  font-size: 14px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  transition: background .15s, transform .12s, box-shadow .15s;
  margin-bottom: 14px;
}
#prl-root .prl-btn:hover {
  background: var(--prl-accent-dark);
  box-shadow: 0 4px 14px rgba(24,182,82,.28);
  transform: translateY(-1px);
}
#prl-root .prl-btn:active { transform: translateY(0); }
#prl-root .prl-btn:disabled { opacity: .6; cursor: not-allowed; transform: none; box-shadow: none; }

/* Spinner */
#prl-root .prl-btn-spinner {
  width: 15px;
  height: 15px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: prl-spin .65s linear infinite;
  flex-shrink: 0;
}
@keyframes prl-spin { to { transform: rotate(360deg); } }

/* Switch + Terms */
#prl-root .prl-switch { margin: 0; text-align: center; font-size: 13px; color: var(--prl-text-muted); }
#prl-root .prl-switch-link {
  background: none; border: none; color: var(--prl-accent);
  font-weight: 600; cursor: pointer; font-size: 13px;
  font-family: inherit; padding: 0;
}
#prl-root .prl-switch-link:hover { text-decoration: underline; }


/* Consent checkbox */
#prl-root .prl-consent {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin: 2px 0 14px;
    cursor: pointer;
    font-size: 12px;
    color: var(--prl-text-muted);
    line-height: 1.55;
    user-select: none;
}
#prl-root .prl-consent input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--prl-accent);
    cursor: pointer;
    flex-shrink: 0;
    margin-top: 1px;
}
#prl-root .prl-consent a {
    color: var(--prl-accent);
    text-decoration: none;
    font-weight: 500;
}
#prl-root .prl-consent a:hover { text-decoration: underline; }
#prl-root .prl-consent--error {
    color: var(--prl-error);
}
#prl-root .prl-consent--error input[type="checkbox"] {
    outline: 2px solid var(--prl-error);
    outline-offset: 1px;
    border-radius: 3px;
}

#prl-root .prl-terms {
  font-size: 12px; color: var(--prl-text-muted);
  text-align: center; margin: -2px 0 13px; line-height: 1.6;
}

/* Consent checkbox */
#prl-root .prl-consent {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin: 2px 0 14px;
    cursor: pointer;
    font-size: 12px;
    color: var(--prl-text-muted);
    line-height: 1.55;
    user-select: none;
}
#prl-root .prl-consent input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--prl-accent);
    cursor: pointer;
    flex-shrink: 0;
    margin-top: 1px;
}
#prl-root .prl-consent a {
    color: var(--prl-accent);
    text-decoration: none;
    font-weight: 500;
}
#prl-root .prl-consent a:hover { text-decoration: underline; }
#prl-root .prl-consent--error {
    color: var(--prl-error);
}
#prl-root .prl-consent--error input[type="checkbox"] {
    outline: 2px solid var(--prl-error);
    outline-offset: 1px;
    border-radius: 3px;
}

#prl-root .prl-terms a { color: var(--prl-accent); text-decoration: none; font-weight: 500; }

/* Consent checkbox */
#prl-root .prl-consent {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin: 2px 0 14px;
    cursor: pointer;
    font-size: 12px;
    color: var(--prl-text-muted);
    line-height: 1.55;
    user-select: none;
}
#prl-root .prl-consent input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--prl-accent);
    cursor: pointer;
    flex-shrink: 0;
    margin-top: 1px;
}
#prl-root .prl-consent a {
    color: var(--prl-accent);
    text-decoration: none;
    font-weight: 500;
}
#prl-root .prl-consent a:hover { text-decoration: underline; }
#prl-root .prl-consent--error {
    color: var(--prl-error);
}
#prl-root .prl-consent--error input[type="checkbox"] {
    outline: 2px solid var(--prl-error);
    outline-offset: 1px;
    border-radius: 3px;
}

#prl-root .prl-terms a:hover { text-decoration: underline; }

/* Panel anim */
#prl-root .prl-panel { animation: prl-panel-in .18s ease both; }
@keyframes prl-panel-in { from{opacity:0;transform:translateY(4px)} to{opacity:1;transform:translateY(0)} }

/* ── Responsive ────────────────────────────────────────────────── */
@media (max-width: 600px) {
  #prl-root {
    padding: 16px 12px 32px;
    align-items: flex-start;
  }
  #prl-root .prl-card {
    padding: 22px 18px 20px;
    border-radius: 16px;
    max-width: 100%;
  }
  #prl-root .prl-brand-name { font-size: 15px; }
  #prl-root .prl-tab { padding: 7px 8px; font-size: 12px; }
}

@media (max-width: 380px) {
  #prl-root .prl-card { padding: 18px 14px 16px; }
}

/* Nextend Google button — inject Google icon via CSS if missing */
#prl-root .prl-social-wrap .nsl-button-google .nsl-button-default-icon,
#prl-root .prl-social-wrap .nsl-button-google .nsl-button-svg-container {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z' fill='%234285F4'/%3E%3Cpath d='M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z' fill='%2334A853'/%3E%3Cpath d='M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l3.66-2.84z' fill='%23FBBC05'/%3E%3Cpath d='M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z' fill='%23EA4335'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-size: 18px 18px !important;
  background-position: center !important;
}

/* Hide any broken img tags inside icon area, keep background icon */
#prl-root .prl-social-wrap .nsl-button-google .nsl-button-default-icon img[src=""],
#prl-root .prl-social-wrap .nsl-button-google .nsl-button-default-icon img:not([src]) {
  visibility: hidden !important;
  width: 0 !important;
}

/* ── Google icon fallback (Nextend sometimes leaves img src empty) ── */
#prl-root .prl-social-wrap .nsl-button-google .nsl-button-default-icon,
#prl-root .prl-social-wrap .nsl-button-google .nsl-button-svg-container {
  min-width: 20px !important;
  overflow: visible !important;
}

/* If Nextend renders the Google icon as a background-image on the container */
#prl-root .prl-social-wrap .nsl-button-google .nsl-button-default-icon img[src=""],
#prl-root .prl-social-wrap .nsl-button-google .nsl-button-default-icon img:not([src]) {
  /* Replace broken img with inline Google SVG via CSS */
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='18' height='18'%3E%3Cpath d='M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z' fill='%234285F4'/%3E%3Cpath d='M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z' fill='%2334A853'/%3E%3Cpath d='M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l3.66-2.84z' fill='%23FBBC05'/%3E%3Cpath d='M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z' fill='%23EA4335'/%3E%3C/svg%3E") !important;
  width: 18px !important;
  height: 18px !important;
}
