/*
Theme Name:   GeneratePress EscortClients
Theme URI:    https://escortclients.com
Description:  GeneratePress Child Theme for EscortClients
Author:       EscortClients
Template:     generatepress
Version:      1.0.0
Text Domain:  generatepress-escort
*/

:root{
  --gold:#C9A96E;
  --gold-light:#E8D5B0;
  --gold-dark:#8A6F44;
  --muted:#8A8279;
  --text:#F2EDE6;
  --black:#0D0D0D;
  --surface:#1A1A1A;
  --surface2:#222;
  --border:rgba(201,169,110,0.2);
  --green:#1D9E75;
}

/* GLOBAL */
html, body{
  margin:0;
  padding:0;
  background:var(--black);
  color:var(--text);
  font-family:'Jost',sans-serif;
  line-height:1.7;
}

body{
  background:var(--black) !important;
  color:var(--text);
  font-family:'Jost',sans-serif;
}

.container,
.inside-article,
.entry-content,
.site-content{
  max-width:1200px;
  margin:0 auto;
  padding:0 2rem;
}

/* FORCE DARK REGISTER PAGE + REMOVE ASTRA WHITE WRAPPERS */
body.page-id-230,
body.page-id-230 .site,
body.page-id-230 .site-content,
body.page-id-230 #content,
body.page-id-230 #primary,
body.page-id-230 .content-area,
body.page-id-230 .ast-container,
body.page-id-230 .entry-content,
body.page-id-230 article,
body.page-id-230 .site-primary-footer-wrap,
body.page-id-230 .site-below-footer-wrap{
  background:#0D0D0D !important;
}

body.page-id-230 .ast-container{
  max-width:100% !important;
  padding-left:0 !important;
  padding-right:0 !important;
}

body.page-id-230 .entry-content{
  margin:0 !important;
  padding:0 !important;
}

body.page-id-230 .entry-header,
body.page-id-230 .post-thumb,
body.page-id-230 .ast-single-post-order{
  display:none !important;
}

/* AUTH LAYOUT */
.auth-wrap{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#0D0D0D;
  padding:6rem 1.5rem;
}

.auth-wrap-register{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#0D0D0D;
  padding:6rem 1.5rem;
}

.auth-card{
  background:#1A1A1A;
  border:1px solid var(--border);
  padding:3rem;
  max-width:420px;
  width:100%;
}

.auth-card-register{
  background:#1A1A1A !important;
  border:1px solid var(--border) !important;
  padding:3rem !important;
  max-width:760px !important;
  width:100% !important;
  margin:0 auto !important;
}

/* TEXT */
.page-eyebrow{
  font-size:11px;
  letter-spacing:4px;
  text-transform:uppercase;
  color:#8A6F44;
  margin-bottom:.75rem;
}

.auth-card h1,
.auth-card-register h1{
  font-size:38px;
  color:var(--gold);
  margin-bottom:.5rem;
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
}

.auth-card > p,
.auth-card-register > p{
  color:var(--muted);
  margin-bottom:2rem;
}

/* LOGIN FORM */
.mepr-login-wrap form,
.mepr-login-wrap .mp_wrapper{
  width:100% !important;
  background:transparent !important;
  border:none !important;
  padding:0 !important;
}

.mepr-login-wrap > form > div > label,
.mepr-login-wrap label.mepr-form-label,
.mepr-login-wrap .mp-form-label,
.mepr-login-wrap .mepr-form-row label{
  display:block !important;
  font-size:11px !important;
  letter-spacing:1.5px !important;
  text-transform:uppercase !important;
  color:var(--muted) !important;
  margin-bottom:6px !important;
  font-family:'Jost',sans-serif !important;
  width:auto !important;
  padding:0 !important;
}

.mepr-login-wrap input[type="text"],
.mepr-login-wrap input[type="email"],
.mepr-login-wrap input[type="password"]{
  width:100% !important;
  background:#222 !important;
  border:1px solid var(--border) !important;
  color:var(--text) !important;
  padding:12px !important;
  margin-bottom:1rem !important;
  box-sizing:border-box !important;
}

.mepr-login-wrap input[type="submit"]{
  width:100% !important;
  background:var(--gold) !important;
  color:#000 !important;
  border:none !important;
  padding:14px !important;
  text-transform:uppercase;
  letter-spacing:2px;
  cursor:pointer;
  font-weight:500;
}

.mepr-login-wrap input[type="submit"]:hover{
  opacity:0.85 !important;
}

/* REMOVE PASSWORD TOGGLE / EYE / BUTTON */
.mepr-login-wrap .mp-password-toggle,
.mepr-login-wrap .mepr-password-toggle,
.mepr-login-wrap .mp-password-toggle-wrap,
.mepr-login-wrap .mepr-icon-eye,
.mepr-login-wrap .mp-password-icon,
.mepr-login-wrap button[aria-label*="password"],
.mepr-login-wrap button[aria-label*="Password"],
button.button.mp-hide-pw,
button.mp-hide-pw,
.mp-hide-pw,
.hide-if-no-js.mp-hide-pw{
  display:none !important;
}

/* REMEMBER ME */
.mepr-login-wrap .mepr-form-remember-me,
.mepr-login-wrap .mepr-checkboxes-field,
.mepr-login-wrap .mepr-field-group-remember-me{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:8px !important;
  margin:10px 0 16px !important;
  width:100% !important;
  min-height:auto !important;
}

.mepr-login-wrap input[type="checkbox"]{
  display:inline-block !important;
  width:14px !important;
  height:14px !important;
  margin:0 !important;
  padding:0 !important;
  vertical-align:middle !important;
  accent-color:var(--gold) !important;
  flex-shrink:0 !important;
}

.mepr-login-wrap label[for*="remember"],
.mepr-login-wrap label[for*="mepr_form_remember"],
.mepr-login-wrap label[for*="remember-me"],
.mepr-login-wrap .mepr-form-remember-me label{
  display:inline-block !important;
  color:var(--muted) !important;
  font-size:11px !important;
  letter-spacing:1.5px !important;
  text-transform:uppercase !important;
  cursor:pointer !important;
  margin:0 !important;
  padding:0 !important;
  line-height:1 !important;
  vertical-align:middle !important;
  width:auto !important;
}

/* REGISTER PAGE */
.role-section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;
  color:var(--text);
  margin-bottom:1rem;
}

.role-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
  margin-bottom:1.5rem;
}

.role-btn{
  background:var(--surface2);
  border:2px solid var(--border);
  color:var(--muted);
  padding:1.5rem;
  cursor:pointer;
  font-family:'Jost',sans-serif;
  transition:all .2s;
  text-align:center;
}

.role-btn:hover,
.role-btn.active{
  border-color:var(--gold);
  color:var(--gold);
  background:rgba(201,169,110,0.15);
}

.role-icon{
  font-size:28px;
  display:block;
  margin-bottom:.5rem;
}

.role-name{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;
  font-weight:400;
  display:block;
  color:inherit;
  margin-bottom:.25rem;
}

.role-desc{
  font-size:12px;
  color:var(--muted);
  display:block;
  line-height:1.4;
}

.form-divider{
  height:1px;
  background:var(--border);
  margin:1.75rem 0;
}

/* MEMBERPRESS REGISTER FORM */
.membership-form,
.membership-form form,
.mepr-membership-registration-form,
.mepr-form,
.auth-card-register .mepr-membership-registration-form,
.auth-card-register .mepr-form,
.auth-card-register form{
  width:100% !important;
  max-width:100% !important;
}

.mepr-membership-registration-form{
  margin-top:0;
}

.mepr-form{
  margin:0;
}

.mepr-form-row,
.auth-card-register .mepr-form-row,
.mepr-form-field .mepr-form-row{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:1rem !important;
}

.mepr-form-field{
  margin-bottom:1.25rem;
  width:100% !important;
}

.mepr-form-field label{
  display:block;
  font-size:11px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--muted) !important;
  margin-bottom:6px;
}

.mepr-form-field input[type="text"],
.mepr-form-field input[type="email"],
.mepr-form-field input[type="password"],
.mepr-form-field input[type="tel"],
.mepr-form-field select,
.auth-card-register .mepr-form-field input[type="text"],
.auth-card-register .mepr-form-field input[type="email"],
.auth-card-register .mepr-form-field input[type="password"],
.auth-card-register .mepr-form-field input[type="tel"],
.auth-card-register .mepr-form-field select{
  width:100% !important;
  min-width:0 !important;
  background:#222 !important;
  border:1px solid rgba(201,169,110,0.2) !important;
  color:#F2EDE6 !important;
  padding:12px 14px;
  font-size:14px;
  font-family:'Jost',sans-serif !important;
  outline:none;
  transition:border-color .2s;
  border-radius:0 !important;
  box-sizing:border-box;
}

.mepr-form-field input:focus,
.mepr-form-field select:focus{
  border-color:var(--gold) !important;
}

.mepr-form-field input::placeholder{
  color:#555 !important;
}

.mepr-form-field .mepr-form-description{
  font-size:12px;
  color:var(--muted) !important;
  margin-top:5px;
}

.mepr-form-field .mepr-terms-field{
  margin-bottom:1.25rem;
}

.mepr-form-field .mepr-terms-field label{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:13px;
  color:var(--text) !important;
  line-height:1.5;
  text-transform:none;
  letter-spacing:0;
}

.mepr-form-field .mepr-terms-field input[type="checkbox"]{
  accent-color:var(--gold);
  margin-top:3px;
  flex-shrink:0;
  width:16px;
  height:16px;
  cursor:pointer;
}

.mepr-form-field .mepr-terms-field a{
  color:var(--gold) !important;
  transition:opacity .2s;
}

.mepr-form-field .mepr-terms-field a:hover{
  opacity:.75;
}

.mepr-form-field input[type="submit"],
.mepr-form input[type="submit"],
.auth-card-register .mepr-form-submit,
.auth-card-register .mepr-submit{
  width:100% !important;
  background:var(--gold) !important;
  color:#000 !important;
  border:none !important;
  padding:15px !important;
  font-size:12px;
  letter-spacing:2px;
  text-transform:uppercase;
  cursor:pointer;
  font-family:'Jost',sans-serif !important;
  font-weight:500;
  margin-top:1.5rem;
  transition:opacity .2s;
  border-radius:0 !important;
}

.mepr-form-field input[type="submit"]:hover,
.mepr-form input[type="submit"]:hover{
  opacity:.85;
}

.auth-card-register .mepr_price{
  color:var(--gold) !important;
  font-size:14px !important;
  margin-bottom:1rem !important;
}

/* REMOVE MEMBERPRESS JUNK */
div.mepr_spacer,
.mepr_spacer{
  display:none !important;
  height:0 !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
}

#mepr_no_val,
input#mepr_no_val,
input[name="mepr_no_val"]{
  display:none !important;
  visibility:hidden !important;
  opacity:0 !important;
  position:absolute !important;
  left:-99999px !important;
  width:1px !important;
  height:1px !important;
  pointer-events:none !important;
}

.mepr-hidden,
.mepr-visuallyhidden,
.mepr-form .mepr-hidden,
.mepr-form .mepr-visuallyhidden,
.mepr-membership-registration-form .mepr-hidden,
.mepr-membership-registration-form .mepr-visuallyhidden{
  display:none !important;
}

.mepr-form > div:empty,
.mepr-membership-registration-form > div:empty{
  display:none !important;
  margin:0 !important;
  padding:0 !important;
}

/* LINKS */
.auth-link{
  text-align:center;
  margin-top:1rem;
  font-size:13px;
  color:var(--muted);
}

.auth-link a{
  color:var(--gold);
  text-decoration:none;
}

.auth-link a:hover{
  opacity:0.75;
}

.auth-divider{
  margin:1.5rem 0;
  text-align:center;
  color:var(--muted);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:1.5px;
}

/* ERROR / SUCCESS */
.mepr_error,
.mp_error,
.mepr-validation-error,
.errors,
.error{
  background:rgba(229,121,93,.06) !important;
  border:1px solid rgba(229,121,93,.4) !important;
  color:#E5795D !important;
  padding:.875rem 1rem !important;
  margin-bottom:1rem !important;
  font-size:13px !important;
}

.mepr_success,
.mp_success,
.mepr-validation-success,
.success{
  background:rgba(29,158,117,.06) !important;
  border:1px solid rgba(29,158,117,.4) !important;
  color:#1D9E75 !important;
  padding:.875rem 1rem !important;
  margin-bottom:1rem !important;
  font-size:13px !important;
}

/* MOBILE */
@media (max-width:768px){
  .auth-card{
    padding:2rem 1.25rem;
  }

  .auth-card-register{
    max-width:100% !important;
    padding:2rem 1.25rem !important;
  }

  .auth-card h1,
  .auth-card-register h1{
    font-size:34px;
  }

  .mepr-form-row,
  .auth-card-register .mepr-form-row,
  .mepr-form-field .mepr-form-row{
    grid-template-columns:1fr !important;
  }

  .role-grid,
  .auth-card-register .role-grid{
    grid-template-columns:1fr 1fr !important;
  }
}