*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; background-color: #0D1B2A; font-family: 'Poppins', sans-serif; }


.pp-header {
  display: none;
}

.pp-footer {
  display: none;
}

/* ── DESKTOP ─────────────────────────────────────────── */
.pp-signup-page-inner > .desktop-wrap {
  display: flex;
  height: 100vh;
  max-height: 100vh;
  overflow: hidden;
  min-height: 0;
}

/* LEFT: dark navy, exactly 50% */
.left-panel {
  width: 50%;
  flex: 0 0 50%;
  background-color: #0D1B2A;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: 40px 0 40px 0;
  height: 100%;
  min-height: 0;
  overflow-y: auto;
  box-sizing: border-box;
}

.left-content {
  width: 100%;
  max-width: 460px;
  padding: 0;
  flex: 1;
}

.left-content .pp-auth-left-logo {
  width: 100%;
  max-width: 460px;
  padding: 0 0 20px 0;
  margin: 0 0 8px 0;
}
.pp-auth-left-logo__img {
  width: 160px;
  height: auto;
  display: block;
}

.s1-eyebrow {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 800; font-size: 13px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: #00C2CB;
  margin-bottom: 10px;
  text-align: left;
}

.s1-headline {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 34px;
  color: #ffffff; line-height: 1.1; margin-bottom: 24px;
  text-align: left;
}

.trust-card {
  background-color: #112236;
  border: 1px solid rgba(0,194,203,0.22);
  border-radius: 14px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 18px;
  margin-bottom: 10px;
  width: 100%;
}
.trust-icon {
  width: 38px; height: 38px; flex-shrink: 0;
  background-color: #0a3040;
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
}
.trust-title { font-weight: 600; font-size: 14px; color: #ffffff; margin-bottom: 4px; }
.trust-body  { font-size: 12px; color: rgba(255,255,255,0.52); line-height: 1.55; }

.lock-callout {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 18px;
  background: linear-gradient(135deg, rgba(0,194,203,0.12), rgba(0,194,203,0.05));
  border: 1px solid rgba(0,194,203,0.4);
  border-radius: 12px;
  margin-top: 72px;
  margin-bottom: 10px;
  width: 100%;
}

.social-bar {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 16px;
  background-color: #112236;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.09);
  width: 100%;
}
.avatars { display: flex; }
.av {
  width: 30px; height: 30px; border-radius: 50%;
  border: 2px solid #0D1B2A;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 600; margin-left: -8px; color: #fff;
}
.av:first-child { margin-left: 0; }
.social-text { font-size: 12px; color: rgba(255,255,255,0.58); line-height: 1.45; }
.social-text strong { color: #ffffff; font-weight: 600; }

/* RIGHT: bright white panel, exactly 50% — scroll inside column only */
.right-panel {
  width: 50%;
  flex: 0 0 50%;
  background-color: #f2f4f7;
  height: 100%;
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: 40px 48px 48px 48px;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  box-sizing: border-box;
}

/* Offer banner */
.offer-banner {
  width: 100%;
  max-width: 420px;
  background-color: #0D1B2A;
  border: 2px solid #00C2CB;
  border-radius: 10px;
  padding: 16px 20px;
  text-align: center;
  margin-bottom: 16px;
}
.offer-banner-title {
  font-family: 'Poppins', sans-serif;
  font-weight: 700; font-size: 15px; color: #ffffff;
  margin-bottom: 6px;
}
.offer-banner-badge {
  display: inline-block;
  border: 2px solid #00C2CB;
  border-radius: 4px;
  padding: 4px 14px;
  font-size: 13px; font-weight: 700;
  color: #00C2CB; letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* New accounts pill */
.new-acct-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background-color: #00C2CB;
  border-radius: 20px;
  padding: 7px 18px;
  font-size: 13px; font-weight: 600; color: #0D1B2A;
  margin-bottom: 28px;
  align-self: center;
  max-width: 420px;
}
.pill-check {
  width: 16px; height: 16px;
  background-color: rgba(255,255,255,0.25);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px;
}

/* Tab row */
.tab-row {
  display: flex;
  width: 100%;
  max-width: 420px;
  border-bottom: 2px solid #e0e3e9;
  margin-bottom: 24px;
}
.tab {
  flex: 1; padding: 10px 0; text-align: center;
  font-size: 15px; font-weight: 600;
  color: #aab0bb; cursor: pointer;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  transition: color 0.2s, border-bottom-color 0.2s;
  background: none !important;
  background-color: transparent !important;
  border-left: none; border-right: none; border-top: none;
  font-family: 'Poppins', sans-serif;
  box-shadow: none !important;
}
.tab.on { color: #0D1B2A; border-bottom-color: #00C2CB; }
.tab:hover {
  background: none !important;
  background-color: transparent !important;
  box-shadow: none !important;
}
.tab:hover:not(.on) {
  color: #cfd3da;
  border-bottom-color: rgba(0, 194, 203, 0.35);
}
.tab.on:hover {
  color: #0D1B2A;
  border-bottom-color: #00C2CB;
}
.tab:focus-visible {
  outline: 2px solid #00c2cb;
  outline-offset: 2px;
}

.form-block { display: none; width: 100%; max-width: 420px; }
.form-block.on { display: block; }

/* Fields */
.field { margin-bottom: 18px; width: 100%; }
.field-row { display: flex; gap: 12px; width: 100%; margin-bottom: 18px; }
.field-row .field { margin-bottom: 0; }

label.pp-label {
  display: block; font-size: 13px; font-weight: 500;
  color: #444; margin-bottom: 7px;
}
.pp-input {
  display: block; width: 100%; padding: 13px 16px;
  background-color: #ffffff;
  border: 1.5px solid #d8dce4;
  border-radius: 8px;
  font-family: 'Poppins', sans-serif; font-size: 14px; color: #222;
  outline: none; transition: border-color 0.2s;
  -webkit-appearance: none; appearance: none;
}
.pp-input::placeholder { color: #bbb; }
.pp-input:focus { border-color: #00C2CB; }

.pw-wrap { position: relative; width: 100%; }
.pw-toggle {
  position: absolute; right: 13px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer;
  color: #bbb; padding: 0; display: flex; align-items: center;
  transition: color 0.2s;
}
.pw-toggle:hover { color: #555; }
.pw-toggle svg { stroke: currentColor; }

.disclaimer {
  font-size: 11.5px; color: #777; line-height: 1.65; margin-bottom: 20px; width: 100%;
}
.disclaimer.disclaimer--post-submit {
  margin-top: 0;
  margin-bottom: 18px;
}
.disclaimer a { color: #00868c; text-decoration: none; }
.disclaimer a:hover { text-decoration: underline; }

.pp-login-options {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px 16px;
  width: 100%;
  margin: 0 0 0 0;
}
.pp-login-options .pp-login-remember {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 13px;
  font-weight: 500;
  color: #555;
  cursor: pointer;
}
.pp-login-options .pp-login-remember input {
  margin: 0;
  flex-shrink: 0;
}
.forgot-link {
  display: block; text-align: right; font-size: 12px;
  color: #00868c; text-decoration: none; margin-bottom: 20px;
}
.pp-login-options .forgot-link.pp-login-forgot {
  display: inline-flex;
  align-items: center;
  margin-bottom: 0;
  line-height: 1.35;
  flex-shrink: 0;
}
.forgot-link:hover { text-decoration: underline; }

/* Submit: layout only — theme keeps colors/typography. */
body.pp-signup-page button.pp-auth-submit {
  width: 100%;
  margin-top: 0 !important;
  margin-bottom: 12px !important;
}

.sec-strip {
  display: flex; justify-content: center; gap: 16px; width: 100%;
  margin-bottom: 10px;
}
.sec-item { display: flex; align-items: center; gap: 5px; font-size: 11px; color: #aaa; }

.form-footer-note {
  font-size: 11px; color: #aaa; text-align: center; margin-top: 6px;
}

/* ── MOBILE ──────────────────────────────────────────── */
.mobile-wrap { display: none; }
.mobile-layout { display: none; }

.mob-step { display: block; }
.mob-step.hidden { display: none; }

.mob-trust-card {
  background-color: #112236;
  border: 1px solid rgba(0,194,203,0.22);
  border-radius: 14px;
  padding: 16px 18px;
  display: flex; align-items: flex-start; gap: 14px;
  margin-bottom: 12px;
}
.mob-trust-icon {
  width: 36px; height: 36px; flex-shrink: 0;
  background-color: #0a3040; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
}

.btn-primary-mob {
  display: block; width: 100%; padding: 17px;
  background-color: #00C2CB; border: none; border-radius: 12px;
  font-family: 'Poppins', sans-serif; font-weight: 600; font-size: 16px;
  color: #0D1B2A; cursor: pointer; margin-bottom: 12px;
  -webkit-appearance: none; appearance: none;
}
.btn-secondary-mob {
  display: block; width: 100%; padding: 15px;
  background-color: #ffffff; border: none; border-radius: 12px;
  font-family: 'Poppins', sans-serif; font-weight: 600; font-size: 16px;
  color: #0D1B2A; cursor: pointer;
  -webkit-appearance: none; appearance: none;
}

.mob-badges {
  display: flex; justify-content: center; gap: 14px; margin-top: 14px; margin-bottom: 40px;
}
.mob-badge { display: flex; align-items: center; gap: 5px; font-size: 11px; color: rgba(255,255,255,0.38); }
.mob-dot { width: 6px; height: 6px; border-radius: 50%; background-color: #00C2CB; }

.back-btn {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; color: rgba(255,255,255,0.4);
  background: none; border: none; cursor: pointer;
  font-family: 'Poppins', sans-serif; padding: 0; margin-bottom: 16px;
}

/* Mobile form card is white too */
.mob-form-card {
  background-color: #f2f4f7;
  border-radius: 16px; padding: 24px 20px; margin-bottom: 40px;
}
.mob-offer-banner {
  background-color: #1a5eb8; border-radius: 10px;
  padding: 12px 16px; text-align: center; margin-bottom: 20px;
}
.mob-offer-deal { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 20px; color: #00C2CB; letter-spacing: 0.04em; }
.mob-offer-sub { font-size: 11px; color: rgba(255,255,255,0.55); margin-top: 2px; }

.mob-tab-row { display: flex; border-bottom: 2px solid #d8dce4; margin-bottom: 20px; }
.mob-tab {
  flex: 1; padding: 9px 0; text-align: center;
  font-size: 14px; font-weight: 600; color: #aab0bb; cursor: pointer;
  border-bottom: 3px solid transparent; margin-bottom: -2px;
  background: none; border-left: none; border-right: none; border-top: none;
  font-family: 'Poppins', sans-serif; transition: color 0.2s, border-color 0.2s;
}
.mob-tab.on { color: #0D1B2A; border-bottom-color: #00C2CB; }

.mob-form-block { display: none; }
.mob-form-block.on { display: block; }

.mob-label { display: block; font-size: 13px; font-weight: 500; color: #444; margin-bottom: 7px; }
.mob-input {
  display: block; width: 100%; padding: 13px 16px;
  background-color: #fff; border: 1.5px solid #d8dce4; border-radius: 8px;
  font-family: 'Poppins', sans-serif; font-size: 14px; color: #222;
  outline: none; -webkit-appearance: none; appearance: none;
}
.mob-input::placeholder { color: #bbb; }
.mob-input:focus { border-color: #00C2CB; }
.mob-field { margin-bottom: 16px; }
.mob-field-row { display: flex; gap: 10px; margin-bottom: 16px; }
.mob-field-row .mob-field { flex: 1; margin-bottom: 0; }
.mob-disclaimer { font-size: 11px; color: #777; line-height: 1.65; margin-bottom: 18px; }
.mob-disclaimer a { color: #00868c; text-decoration: none; }
.mob-forgot { display: block; text-align: right; font-size: 12px; color: #1a5eb8; text-decoration: none; margin-bottom: 18px; }

.mob-btn-submit {
  display: block; width: 100%; padding: 15px;
  background-color: #00C2CB; border: none; border-radius: 8px;
  font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 16px;
  color: #0D1B2A; cursor: pointer; margin-bottom: 14px;
  -webkit-appearance: none; appearance: none;
}
.mob-sec-strip { display: flex; justify-content: center; gap: 14px; }
.mob-sec-item { display: flex; align-items: center; gap: 4px; font-size: 11px; color: #aaa; }

@keyframes fadeUp { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }
.anim { animation: fadeUp 0.3s ease both; }

@media (max-width: 800px) {
  .desktop-wrap { display: none !important; }
  .mobile-wrap {
    display: flex; flex-direction: column;
    background-color: #0D1B2A; min-height: 100vh;
  }
  .mob-header { padding: 20px 20px 0; }
  .mob-logo { height: 34px; }
  .mob-content { padding: 20px; flex: 1; }
  .mob-eyebrow {
    font-family: 'Barlow Condensed', sans-serif; font-weight: 800;
    font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
    color: #00C2CB; text-align: center; margin-bottom: 8px;
  }
  .mob-headline {
    font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
    font-size: 32px; color: #fff; text-align: center; line-height: 1.1; margin-bottom: 24px;
  }
  .mob-social { display: flex; align-items: center; gap: 12px; margin: 16px 0 24px; padding: 12px 14px; background-color: #112236; border-radius: 12px; border: 1px solid rgba(255,255,255,0.09); }
  .mob-av { width: 28px; height: 28px; border-radius: 50%; border: 2px solid #0D1B2A; display: flex; align-items: center; justify-content: center; font-size: 9px; font-weight: 600; margin-left: -8px; color: #fff; }
  .mob-av:first-child { margin-left: 0; }
  .mob-avs { display: flex; }
  .mob-social-text { font-size: 11px; color: rgba(255,255,255,0.55); line-height: 1.4; }
  .mob-social-text strong { color: #fff; font-weight: 600; }
}

/* MOBILE */
@media(max-width:768px){
.desktop-wrap{display:none}
.mobile-wrap{display:none !important}
.mobile-layout{display:flex;flex-direction:column;min-height:100vh;background:#0D1B2A;position:relative;overflow-x:hidden}
.mob-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 50% -10%,rgba(0,194,203,0.12) 0%,transparent 55%);pointer-events:none}
.mob-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;padding:40px 20px 40px;min-height:100vh}
.mob-logo{margin-bottom:96px}
.mob-logo img{height:72px;width:auto;filter:brightness(0) invert(1)}
.mob-headline{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:38px;color:#fff;line-height:1.1;text-align:center;margin-bottom:10px}
.mob-headline span{color:#00C2CB;font-style:italic}
.mob-sub{font-size:13px;color:rgba(255,255,255,0.55);text-align:center;margin-bottom:14px;display:flex;align-items:center;gap:7px}
.lock-icon{width:16px;height:20px;display:inline-flex;align-items:flex-end;justify-content:center;flex-shrink:0;position:relative}
.lock-body{width:14px;height:10px;background:#f59e0b;border-radius:2px;position:absolute;bottom:0}
.lock-shackle{width:9px;height:7px;border:2px solid #f59e0b;border-bottom:none;border-radius:5px 5px 0 0;position:absolute;top:1px;left:50%;transform:translateX(-50%)}
.mob-social{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,0.45);margin-bottom:24px}
.mob-avatars{display:flex}
.mob-avatar{width:26px;height:26px;border-radius:50%;border:2px solid #0D1B2A;margin-left:-7px;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff}
.mob-avatar:first-child{margin-left:0}
.mob-card{width:100%;max-width:420px;background:#fff;border-radius:18px;overflow:visible;box-shadow:0 8px 48px rgba(0,0,0,0.35)}
.mob-promo{background:linear-gradient(135deg,#1e6eeb 0%,#0ea5e9 100%);padding:14px 20px;text-align:center}
.mob-promo-top{font-size:13px;font-weight:700;color:#fff;margin-bottom:6px}
.mob-promo-cta{display:inline-block;border:1.5px solid rgba(255,255,255,0.6);border-radius:6px;color:#fff;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:5px 16px}
.mob-new-pill{display:flex;align-items:center;justify-content:center;gap:7px;background:#16a34a;color:#fff;font-size:13px;font-weight:600;padding:10px 20px}
.mob-new-pill .check{width:18px;height:18px;background:rgba(255,255,255,0.25);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px}
.mob-card .mob-promo{border-radius:18px 18px 0 0;overflow:hidden}
.mob-form-body{padding:20px 22px 32px;box-sizing:border-box;overflow:visible}
.mob-tabs{display:flex;border-bottom:1.5px solid #e5e7eb;margin-bottom:20px}
.mob-tab{flex:1;background:none!important;background-color:transparent!important;border:none;box-shadow:none!important;padding:10px 0;font-family:'Poppins',sans-serif;font-size:14px;font-weight:500;color:#9ca3af;cursor:pointer;position:relative;transition:color 0.2s,border-bottom-color 0.2s}
.mob-tab.active{color:#111;font-weight:700}
.mob-tab.active::after{content:'';position:absolute;bottom:-1.5px;left:0;right:0;height:2.5px;background:#00c2cb}
.mob-tab:hover{background:none!important;background-color:transparent!important;box-shadow:none!important}
.mob-tab:hover:not(.active){color:#c5c8ce}
.mob-tab:hover:not(.active)::after{content:'';position:absolute;bottom:-1.5px;left:0;right:0;height:2.5px;background:rgba(0,194,203,0.35)}
.mob-tab.active:hover::after{background:#00c2cb}
.mob-tab:focus-visible{outline:2px solid #00c2cb;outline-offset:2px}
.mob-label{display:block;font-size:13px;font-weight:600;color:#111;margin-bottom:7px}
.mob-input{width:100%;padding:12px 14px;border:1.5px solid #e5e7eb;border-radius:8px;font-family:'Poppins',sans-serif;font-size:14px;color:#111;background:#f9fafb;margin-bottom:14px;outline:none}
.mob-input::placeholder{color:#bbb}
.mob-bottom-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.mob-remember{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:#555;line-height:1.35;margin:0}
.mob-remember input[type=checkbox]{width:15px;height:15px;margin:0;flex-shrink:0;accent-color:#00c2cb;vertical-align:middle}
.mob-forgot{font-size:13px;line-height:1.35;color:#1e6eeb;text-decoration:none;font-weight:500;display:inline-flex;align-items:center;flex-shrink:0;margin-bottom:0}
.mob-disclaimer{font-size:11px;color:#bbb;text-align:center;line-height:1.5}
.mob-disclaimer a{color:#1e6eeb;text-decoration:none}
/* Login submit is the only mobile CTA with .woocommerce-form-login__submit; themes often
   negative-margin / full-bleed that selector so it sits outside the padded login box. */
.pp-signup-page .mobile-layout form.woocommerce-form-login.login .woocommerce-form-login__submit,
.pp-signup-page .mobile-layout form.woocommerce-form-login.login button.pp-auth-submit{
  float:none!important;
  display:block!important;
  width:100%!important;
  max-width:100%!important;
  margin-left:0!important;
  margin-right:0!important;
  position:static!important;
  left:auto!important;
  transform:none!important;
  box-sizing:border-box!important;
}
}

/* WooCommerce compatibility */
.pp-signup-page-inner {
position: relative;
}
/* Turnstile: no visible footprint until submit (execute) / until Cloudflare needs a challenge (interaction-only). */
.pp-turnstile-host {
position: fixed;
left: 0;
right: 0;
bottom: 0;
height: 0;
z-index: 999999;
overflow: visible;
pointer-events: none;
}
.pp-turnstile-host > * {
pointer-events: auto;
}

.pp-signup-page .woocommerce-error,
.pp-signup-page .woocommerce-message,
.pp-signup-page .woocommerce-info {
max-width: 420px;
margin: 0 auto 16px;
box-sizing: border-box;
}
.pp-signup-page .password-input {
display: block;
width: 100%;
}
.pp-auth-left-logo__text {
font-family: 'Barlow Condensed', sans-serif;
font-weight: 800;
font-size: 28px;
color: #ffffff;
line-height: 1;
display: block;
}
.pp-checkbox-row {
display: flex;
align-items: flex-start;
gap: 10px;
font-size: 13px;
color: #444;
line-height: 1.45;
margin-bottom: 16px;
}
.pp-checkbox-row input[type='checkbox'] {
margin-top: 3px;
flex-shrink: 0;
width: 16px;
height: 16px;
accent-color: #00c2cb;
}
.pp-checkbox-row a {
color: #00868c;
text-decoration: none;
}
.pp-checkbox-row a:hover {
text-decoration: underline;
}
