.cpi-auth-page{max-width:1200px;margin:0 auto;padding:24px 14px;font-family:Arial,Helvetica,sans-serif}
.cpi-auth-inner{width:100%}
.cpi-auth-card{background:#fff;border:1px solid #d8d8d8;padding:22px 22px 18px}
.cpi-auth-title{margin:0 0 10px;font-size:28px;color:#5c8b00;letter-spacing:0.5px}
.cpi-auth-lead{margin:6px 0 14px;font-size:13px;color:#111}
.cpi-auth-sublead{margin:14px 0 12px;font-size:13px;color:#111}
.cpi-auth-divider{border:none;border-top:1px solid #d8d8d8;margin:14px 0 14px}

.cpi-org-lookup label,.cpi-org-role label{display:block;font-size:13px;font-weight:bold;margin-bottom:6px}
.cpi-org-lookup-row{display:flex;gap:10px;align-items:center}
.cpi-org-lookup-row input{flex:1;max-width:520px}
.cpi-org-role input{max-width:520px}

.cpi-org-suggestions{position:relative;max-width:520px}
.cpi-org-suggestions .item,.cpi-org-suggestions .cpi-org-suggestion{display:block;width:100%;text-align:left;background:#fff;border:1px solid #d8d8d8;border-top:none;padding:8px 10px;cursor:pointer;font-size:13px}
.cpi-org-suggestions .item:hover,.cpi-org-suggestions .cpi-org-suggestion:hover{background:#f5f5f5}

.cpi-org-loading{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #d8d8d8;border-top:none;padding:8px 10px;font-size:13px;color:#555}
.cpi-spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(0,0,0,.15);border-top-color:rgba(0,0,0,.55);border-radius:50%;animation:cpiSpin .8s linear infinite}
@keyframes cpiSpin{to{transform:rotate(360deg)}}

.cpi-auth-form label{font-size:13px;font-weight:bold}
.cpi-auth-grid{display:grid;grid-template-columns:160px 1fr;gap:10px 18px;align-items:center;max-width:760px}
.cpi-auth-grid input{height:30px;border:1px solid #bfbfbf;border-radius:2px;padding:5px 8px;font-size:13px}

.cpi-password-policy{position:sticky;top:120px;width:100%;max-width:520px;margin:18px auto;background:#5c8b00;color:#fff;padding:14px;border-radius:6px}
.cpi-password-policy-title{font-weight:bold;margin-bottom:8px}
.cpi-password-policy ul{margin:0;padding-left:0;list-style:none}
.cpi-password-policy li{position:relative;font-size:12px;margin:6px 0;opacity:0.95;padding-left:18px}
.cpi-password-policy li.ok{opacity:1}
.cpi-password-policy li:before{content:"○";position:absolute;left:0;top:0;opacity:0.75}
.cpi-password-policy li.ok:before{content:"✓";opacity:1}

.cpi-terms{margin-top:18px}
.cpi-terms h2{font-size:20px;color:#5c8b00;margin:0 0 10px}
.cpi-checkbox{display:block;font-size:13px;margin:8px 0}
.cpi-checkbox input{margin-right:8px}

.cpi-auth-actions{display:flex;align-items:center;justify-content:space-between;margin-top:18px}
.cpi-auth-error{color:#7a1010;font-size:15px;line-height:1.45;font-weight:500;min-height:18px}

.cpi-btn{border:none;border-radius:18px;padding:8px 18px;font-weight:bold;cursor:pointer;font-size:13px}
.cpi-btn-primary{background:#5c8b00;color:#fff}
.cpi-btn-next{background:#5c8b00;color:#fff}
.cpi-btn-white{display:inline-block;background:#fff;color:#111;text-decoration:none;border:1px solid #d8d8d8;border-radius:22px;padding:10px 18px;font-weight:bold}

.cpi-auth-notice{padding:10px 12px;border:1px solid #d8d8d8;margin:10px 0 14px;font-size:13px}
.cpi-auth-notice.success{border-color:#5c8b00;color:#1f4a00}
.cpi-auth-notice.error{border-color:#b00020;color:#b00020}

/* Profile - Edit profile */
.cpi-profile-heading{margin:18px 0 10px;font-size:16px;letter-spacing:0.06em;text-transform:uppercase;color:#111}
.cpi-profile-form{max-width:980px}
.cpi-profile-grid{display:grid;gap:14px 18px;margin:0 0 12px}
.cpi-profile-grid-3{grid-template-columns:100px 1fr 1fr}
.cpi-profile-grid-2{grid-template-columns:1fr 1fr}
.cpi-profile-grid-1{grid-template-columns:1fr}
.cpi-profile-field label{display:block;font-size:13px;font-weight:bold;margin-bottom:6px}
.cpi-profile-field input,.cpi-profile-field select{width:100%;height:30px;border:1px solid #bfbfbf;border-radius:2px;padding:5px 8px;font-size:13px}
.cpi-profile-field small{display:block;margin-top:6px;font-size:12px;color:#6b7280}
.cpi-profile-actions{display:flex;align-items:center;justify-content:center;margin-top:12px}
.cpi-profile-org{display:none}
@media (max-width: 860px){
  .cpi-profile-grid-3{grid-template-columns:1fr}
  .cpi-profile-grid-2{grid-template-columns:1fr}
  .cpi-profile-actions{flex-direction:column;align-items:stretch;gap:10px}
  .cpi-profile-actions .cpi-btn{width:100%}
}

/* Legacy login layout (kept if used elsewhere) */
.cpi-auth-login-layout{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:start}
.cpi-auth-sidebox{background:#5c8b00;color:#fff;padding:18px 18px 22px}
.cpi-auth-sidebox h2{margin:0 0 10px;font-size:20px}
.cpi-auth-sidebox p{font-size:13px;line-height:1.4;margin:10px 0}

.cpi-wp-login-wrap form{margin-top:12px}
.cpi-wp-login-wrap label{display:block;font-size:13px;font-weight:bold;margin-top:10px}
.cpi-wp-login-wrap input[type="text"],.cpi-wp-login-wrap input[type="password"],.cpi-wp-login-wrap input[type="email"]{width:100%;height:30px;border:1px solid #bfbfbf;border-radius:2px;padding:5px 8px;font-size:13px}
.cpi-wp-login-wrap input[type="submit"]{margin-top:12px}
.cpi-forgot{display:inline-block;margin-top:10px;font-size:13px}

/* Responsive */
@media (max-width: 980px){
  .cpi-password-policy{position:static;max-width:none;width:auto;margin-top:12px}
  .cpi-auth-login-layout{grid-template-columns:1fr}
}

.cpi-btn[disabled]{opacity:0.55;cursor:not-allowed}

/* Account home links */
.cpi-account-links{margin:6px 0 14px;font-size:13px}
.cpi-account-links a{display:block;margin:4px 0;color:#5c8b00;text-decoration:underline}
.cpi-account-links a:hover{text-decoration:none}

/* Unlocked member content list */
.cpi-unlocked-list{margin:0;padding-left:18px}
.cpi-unlocked-list li{margin:6px 0;font-size:13px}
.cpi-unlocked-list a{color:#5c8b00;text-decoration:underline}

/* Password policy inline (under fields) */
.cpi-password-policy.inline{position:static;top:auto;max-width:520px;margin:12px 0 0 0;border-radius:0}

.cpi-auth-section-title{margin:0 0 10px;font-size:16px;font-weight:bold;color:#5c8b00;letter-spacing:0.3px}

.cpi-login-card{max-width:960px;margin:0 auto}
.cpi-link{color:#5c8b00;text-decoration:underline}
.cpi-login-register-embed .cpi-auth-card{border:none;padding:0;margin:0}

/* Logout link */
.cpi-account-links .cpi-logout-link{font-weight:600;}

/* Unlocked rules (profile content view) */
.cpi-unlocked-rules{margin-top:10px}
.cpi-rule-card{border:1px solid #e5e5e5;border-radius:12px;padding:14px;margin:0 0 12px;background:#fff}
.cpi-rule-row{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-start}
.cpi-rule-col{min-width:180px}
.cpi-rule-col-url{flex:2;min-width:260px;position:relative}
.cpi-rule-label{font-size:12px;font-weight:600;color:#333;margin:0 0 6px}
.cpi-rule-input{width:100%;padding:10px 12px;border:1px solid #d9d9d9;border-radius:10px;background:#fafafa;font-size:13px}
.cpi-rule-open{display:inline-block;margin-top:8px;font-size:13px;color:#5c8b00;text-decoration:underline}
.cpi-rule-col-levels{flex:1}
.cpi-rule-levels{display:flex;flex-direction:column;gap:6px}
.cpi-rule-level{display:flex;gap:8px;align-items:center;font-size:13px;color:#222}
.cpi-rule-level input{width:16px;height:16px}
.cpi-rule-level.is-mine{font-weight:700}
.cpi-rule-chips{display:flex;flex-wrap:wrap;gap:6px}
.cpi-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#f2f2f2;font-size:12px;color:#222}
.cpi-chip-empty{opacity:.6}

.cpi-auth-login-subtitle{font-weight:600}

/* ---- New Login page (2-column layout with hero + side panel) ---- */
.cpi-login-shell{background:#fff;border:1px solid #d8d8d8}
.cpi-login-hero{height:180px;background-size:cover;background-position:center;border-bottom:1px solid #d8d8d8}

/* IMPORTANT: stretch makes right column match left height */
.cpi-login-grid{display:grid;grid-template-columns:1fr 420px;gap:0;align-items:stretch}

.cpi-login-main{padding:22px}

.cpi-login-side{
  background:#5c8b00;
  color:#fff;
  display:flex;            /* allow vertical centering */
}

/* This is what vertically centers the green panel content */
.cpi-login-side-inner{
  padding:22px;
  display:flex;
  flex-direction:column;
  justify-content:center;  /* vertical centering */
  gap:12px;
  flex:1;                  /* fill full height */
}

.cpi-login-side h2{margin:0 0 12px;font-size:20px;letter-spacing:0.04em}
.cpi-login-side p{margin:0;font-size:13px;line-height:1.4}
.cpi-login-side .cpi-btn-white{margin-top:14px}

.cpi-login-main .cpi-auth-form label{display:block;margin:10px 0 6px}
.cpi-login-main .cpi-auth-form input[type="email"],
.cpi-login-main .cpi-auth-form input[type="password"],
.cpi-login-main .cpi-auth-form input[type="text"]{
  width:100%;
  max-width:520px;
  height:34px;
  border:1px solid #bfbfbf;
  border-radius:2px;
  padding:6px 10px;
  font-size:13px
}

.cpi-login-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;max-width:520px}
.cpi-login-actions .cpi-forgot{margin:0}

.cpi-login-register-embed{border-top:1px solid #d8d8d8;padding:18px 22px}

@media (max-width: 980px){
  .cpi-login-grid{grid-template-columns:1fr}
}

/* My Account page title in site styling */
body.page-my-account .entry-title,
body.page-my-account .page-title,
body.page-slug-my-account .entry-title,
body.page-slug-my-account .page-title,
body.page-my-account h1.entry-title,
body.page-slug-my-account h1.entry-title{color:#5c8b00 !important}

/* Login redesign */
.cpi-login-shell-redesign{border:1px solid #8f8f8f}
.cpi-login-main-redesign{padding:28px 30px 32px}
.cpi-login-page-title{font-size:18px;line-height:1.2;margin:0 0 6px;font-weight:700;letter-spacing:.02em}
.cpi-login-intro{margin:0 0 18px;color:#6a6a6a;font-size:13px}
.cpi-auth-form-redesign{max-width:560px}
.cpi-auth-form-redesign label{display:block;margin:0 0 6px;font-size:13px;font-weight:700;color:#222}
.cpi-auth-form-redesign input[type="email"],
.cpi-auth-form-redesign input[type="password"],
.cpi-auth-form-redesign input[type="text"]{width:100%;max-width:390px;height:32px;border:2px solid #b8b8b8;border-radius:2px;padding:6px 12px;font-size:13px;background:#fff}
.cpi-password-wrap{position:relative;max-width:390px}
.cpi-password-wrap input{padding-right:42px !important}
.cpi-password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:none;background:transparent;cursor:pointer;font-size:15px;line-height:1;padding:0;color:#666}
.cpi-login-row{display:flex;align-items:center;justify-content:space-between;gap:20px;max-width:520px;margin-top:10px}
.cpi-remember-inline{margin:0;font-size:13px;color:#222}
.cpi-remember-inline input{margin-right:8px}
.cpi-btn-login-pill{border-radius:999px;padding:10px 18px;min-width:104px}
.cpi-login-links-row{max-width:390px;border-top:1px solid #9f9f9f;padding-top:10px;margin-top:12px}
.cpi-login-links-row .cpi-forgot{margin:0;font-weight:600;color:#5b5b5b;text-decoration:underline}
.cpi-login-divider{margin:34px 0 18px;border-top:2px solid #9f9f9f}
.cpi-login-register-block h2{margin:0 0 14px;font-size:18px;line-height:1.3;color:#5c8b00;letter-spacing:.01em}
.cpi-login-register-block p{margin:0;font-size:14px;color:#222}
.cpi-inline-link{color:#5c8b00;font-weight:700;text-decoration:underline}
@media (max-width: 700px){
  .cpi-login-main-redesign{padding:20px}
  .cpi-login-row{flex-direction:column;align-items:flex-start}
  .cpi-btn-login-pill{width:100%}
}


/* Universal password eye toggle */
.cpi-pw-icon-wrap{position:relative;display:block;width:100%;max-width:390px}
.cpi-pw-icon-wrap input[type="password"],
.cpi-pw-icon-wrap input[type="text"]{padding-right:42px !important}
.cpi-pw-toggle,
.cpi-password-toggle{position:absolute !important;right:10px;top:50%;transform:translateY(-50%);border:none !important;background:transparent !important;box-shadow:none !important;min-width:auto !important;width:20px;height:20px;padding:0 !important;cursor:pointer;color:#666;line-height:1;z-index:2}
.cpi-pw-toggle:hover,
.cpi-pw-toggle:focus,
.cpi-password-toggle:hover,
.cpi-password-toggle:focus{color:#222;background:transparent !important;outline:none;box-shadow:none !important}
.cpi-pw-toggle svg,
.cpi-password-toggle svg{display:block;width:18px;height:18px;pointer-events:none}
.cpi-auth-form-redesign .cpi-pw-icon-wrap,
.cpi-password-wrap.cpi-pw-icon-wrap{max-width:390px}
.cpi-auth-grid .cpi-pw-icon-wrap,
.cpi-profile-field .cpi-pw-icon-wrap,
.cpi-auth-form .cpi-pw-icon-wrap{max-width:520px}


/* ---- Register redesign ---- */
.cpi-register-card{max-width:940px;margin:0 auto}
.cpi-register-title{padding-bottom:10px;border-bottom:1px solid #a8a8a8;margin-bottom:14px}
.cpi-register-intro{max-width:930px;font-size:13px;font-weight:600;line-height:1.35;margin:0 0 14px;color:#1d1d1d}
.cpi-register-inline-message{display:none;margin:18px 0 0;padding:0;border:none;min-height:0;max-width:780px}
.cpi-register-inline-message.success,
.cpi-register-inline-message.error,
.cpi-register-inline-message.info{display:flex !important;align-items:flex-start;gap:12px;padding:14px 16px;white-space:normal;font-size:15px;line-height:1.45;font-weight:500}
.cpi-register-inline-message.success{border:1px solid #639024;border-left:4px solid #335734;background:#f6fbef;color:#335734}
.cpi-register-inline-message.error{border:1px solid #d93a3a;border-left:4px solid #b00020;background:#fff7f7;color:#7a1010}
.cpi-register-inline-message.info{border:1px solid #b8c7d4;border-left:4px solid #24384a;background:#f5f8fb;color:#24384a}
.cpi-register-inline-message.success::before,
.cpi-register-inline-message.error::before,
.cpi-register-inline-message.info::before{flex:0 0 22px;width:22px;height:22px;border-radius:50%;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;line-height:1;margin-top:1px}
.cpi-register-inline-message.success::before{content:"\2713";background:#639024}
.cpi-register-inline-message.error::before{content:"!";background:#b00020}
.cpi-register-inline-message.info::before{content:"i";background:#24384a;font-family:Georgia,serif;font-style:italic}
.cpi-register-inline-message .cpi-inline-title{display:block;margin:0 0 3px;font-size:15px;font-weight:700;line-height:1.35}
.cpi-register-inline-message .cpi-inline-body{display:block;font-size:15px;font-weight:500;line-height:1.45}
.cpi-register-inline-message.success .cpi-inline-title,
.cpi-register-inline-message.success .cpi-inline-body{color:#335734}
.cpi-register-inline-message.error .cpi-inline-title,
.cpi-register-inline-message.error .cpi-inline-body{color:#7a1010}
.cpi-register-inline-message.info .cpi-inline-title,
.cpi-register-inline-message.info .cpi-inline-body{color:#24384a}
.cpi-register-inline-message a{color:#5c8b00;font-weight:700;text-decoration:underline}
.cpi-auth-error:not(.cpi-register-inline-message){display:block;max-width:780px;margin:12px 0;padding:12px 14px;border:1px solid #d93a3a;border-left:4px solid #b00020;background:#fff7f7;color:#7a1010;white-space:normal}
.cpi-register-grid{grid-template-columns:150px 1fr;gap:10px 16px;max-width:760px;align-items:center}
.cpi-register-grid > label{font-size:13px;font-weight:700;color:#222}
.cpi-register-field{width:100%;max-width:520px;position:relative}
.cpi-register-field input,.cpi-register-field select{width:100%;height:30px;border:1px solid #b5b5b5;border-radius:2px;padding:5px 8px;font-size:13px;background:#fff}
.cpi-register-org-field{display:block}
.cpi-register-org-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:none;width:24px;height:24px;border:none;background:transparent;color:#5c5c5c;font-size:20px;line-height:1;cursor:pointer;padding:0}
.cpi-register-org-field.has-choice .cpi-register-org-clear{display:block}
.cpi-register-org-field.has-choice #cpi_org_search{padding-right:34px}
.cpi-org-suggestions{position:absolute;left:0;right:0;top:100%;z-index:30;max-width:none}
.cpi-register-password-inline{display:flex;gap:10px;align-items:center}
.cpi-register-password-inline > .cpi-pw-icon-wrap{flex:1 1 auto;max-width:none !important}
.cpi-register-password-inline input{width:100%}
.cpi-register-password-inline .cpi-btn{border-radius:4px;padding:7px 14px}
.cpi-register-password-policy{position:static;max-width:520px;margin:16px 0 0 166px;border-radius:0;background:#5c8b00}
.cpi-register-terms{margin-top:28px}
.cpi-register-terms h2{font-size:20px;font-weight:700;letter-spacing:0;color:#5c8b00;margin-bottom:18px}
.cpi-register-terms .cpi-checkbox{display:flex;align-items:flex-start;gap:10px;font-size:13px;font-weight:600;line-height:1.5;margin:10px 0}
.cpi-register-terms .cpi-checkbox input{margin:3px 0 0 0;width:18px;height:18px;flex:0 0 18px}
.cpi-register-actions{justify-content:flex-end;gap:12px;margin-top:18px;max-width:940px}
.cpi-register-actions .cpi-btn-next{min-width:110px;text-transform:uppercase}
.cpi-register-actions .cpi-btn-secondary{background:#fff;color:#5c8b00;border:1px solid #5c8b00}
.cpi-auth-form .cpi-register-inline-message{max-width:780px}
@media (max-width: 860px){
  .cpi-register-grid{grid-template-columns:1fr;gap:8px}
  .cpi-register-password-policy{margin-left:0;max-width:none}
  .cpi-register-password-inline{flex-wrap:wrap}
  .cpi-register-field{max-width:none}
  .cpi-register-actions{justify-content:stretch;flex-direction:column;align-items:stretch}
  .cpi-register-inline-message{margin-left:0;max-width:none}
}
