/* ============================================
   CSS VARIABLES
============================================ */
:root {
    --Typeface-Family-Heading: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --Typeface-Size-h4: 32px;
    --Gray-900: #101828;
}

/* ============================================
   SIGN IN/UP WRAPPER
============================================ */
.zp-sign-in-wrapper {
    display: grid;
    grid-template-columns: 1fr 1.043fr;
    height: 100vh;
    color: #596a6a;
}

@media (max-width: 1024px) {
    .zp-sign-in-wrapper {
        grid-template-columns: 1fr;
        height: auto;
    }
}

/* ============================================
   BRANDING
============================================ */
.zp-sign-in-branding img {
    width: 480px;
    max-width: 100%;
    height: auto;
}

.zp-sign-in-content-text {
    color: #1a2e2e;
    font-size: 24px;
    font-weight: 300;
    line-height: normal;
}

@media (max-width: 1200px) {
    .zp-sign-in-content-text {
        font-size: 20px;
    }
}

@media (max-width: 768px) {
    .zp-sign-in-content-text {
        font-size: 18px;
    }
}

/* ============================================
   FORM CONTENT WRAPPER
============================================ */
.zp-sign-in-form-content-wrapper {
    margin-top: 96px;
    margin-bottom: 96px;
    display: flex;
    justify-content: center;
    padding-inline: 10px;
}

@media (max-width: 1024px) {
    .zp-sign-in-form-content-wrapper {
        order: 1;
        margin-top: 48px;
        margin-bottom: 48px;
        padding-left: 16px;
        padding-right: 16px;
    }
}

.zp-sign-in-form-content {
    max-width: 479px;
    width: 100%;
}

@media (max-width: 1024px) {
    .zp-sign-in-form-content {
        max-width: 100%;
    }
}

/* ============================================
   CONTENT
============================================ */
.zp-sign-in-content {
    margin-bottom: 80px;
}

@media (max-width: 1024px) {
    .zp-sign-in-content {
        display: none;
        margin-bottom: 40px;
    }
}

/* ============================================
   ASIDE WRAPPER - SIN PADDING, SOLO IMAGEN
============================================ */
.zp-sign-in-aside-wrapper {
    background-color: #f5f7f8;
    height: 100%;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    padding: 0; /* Sin padding */
}

@media (max-width: 1024px) {
    .zp-sign-in-aside-wrapper {
        display: block;
    }
}

.zp-sign-in-aside-content {
    display: none; /* Ocultar el texto para que solo se vea imagen */
}

.zp-sign-in-aside-image {
    width: 100%;
    height: 100%;
    line-height: 0;
}

.zp-sign-in-aside-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

@media (max-width: 1024px) {
    .zp-sign-in-aside-image img {
        height: auto;
        object-fit: initial;
    }
}

/* ============================================
   SMALL DEVICES CONTENT
============================================ */
.zp-sign-in-content-small-devices {
    display: none;
}

@media (max-width: 1024px) {
    .zp-sign-in-content-small-devices {
        display: block;
        margin-top: 40px;
        margin-bottom: 40px;
        padding-left: 16px;
        padding-right: 16px;
    }
}

/* ============================================
   SIGNUP LINK
============================================ */
.zp-auth-signup-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #3C6DD0 !important;
    text-decoration: none;
}

.zp-auth-signup-link svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    transition: transform 0.2s ease;
}

.zp-auth-signup-link svg path {
    stroke: #3C6DD0;
}

.zp-auth-signup-link:hover svg {
    transform: translateX(3px);
}

/* ============================================
   FORM STYLES
============================================ */
.auth-page {
    margin: 0;
    padding: 0;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

.zp-auth-form-wrapper {
    width: 100%;
}

.zp-auth-form-head {
    margin-bottom: 32px;
}

.zp-auth-form-title {
    color: var(--Gray-900, #101828);
    font-family: var(--Typeface-Family-Heading, Inter) !important;
    font-size: var(--Typeface-Size-h4, 32px) !important;
    font-style: normal;
    font-weight: 600 !important;
    line-height: 130% !important;
    letter-spacing: -1.6px;
    margin: 0 0 12px 0;
}

@media (max-width: 768px) {
    .zp-auth-form-title {
        font-size: 24px;
        letter-spacing: -1.2px;
    }
}

.zp-auth-form-description {
    font-size: 14px;
    color: #666;
}

.zp-auth-form-description a {
    color: #2563eb;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.zp-auth-form-description a:hover {
    text-decoration: underline;
}

.zp-auth-form-body {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.zp-auth-form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.zp-auth-form-label {
    font-size: 14px;
    font-weight: 500;
    color: #1a1a1a;
}

.zp-auth-form-controls input,
.zp-auth-form-controls select {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    font-size: 14px;
    transition: border-color 0.2s;
}

.zp-auth-form-controls input:focus,
.zp-auth-form-controls select:focus {
    outline: none;
    border-color: #2563eb;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

/* ============================================
   PASSWORD TOGGLE
============================================ */
.zp-auth-form-controls-password {
    position: relative;
}

.zp-auth-form-controls-password input {
    padding-right: 48px;
}

.zp-auth-password-toggle {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.zp-auth-password-toggle:hover {
    opacity: 0.7;
}

.zp-auth-password-toggle svg {
    display: block;
}

/* ============================================
   FORM ACTIONS
============================================ */
.zp-auth-form-actions {
    margin-top: 24px;
}

.zp-auth-form-top-action {
    display: block;
    text-align: right;
    margin-bottom: 16px;
    font-size: 14px;
    color: #2563eb;
    text-decoration: none;
}

.zp-auth-form-top-action:hover {
    text-decoration: underline;
}

.zp-auth-form-actions-row {
    display: flex;
    gap: 12px;
}

@media (max-width: 768px) {
    .zp-auth-form-actions-row {
        flex-direction: column;
    }
}

/* ============================================
   BUTTON PRIMARY
============================================ */
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions .zp-auth-form-button.zp-button.zp-button-primary,
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper button.zp-auth-form-button.zp-button.zp-button-primary,
.zp-auth-form .zp-auth-form-wrapper button.zp-button-primary.zp-auth-form-button {
    /* Layout */
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    box-sizing: border-box !important;
    min-width: 168px !important;
    height: 50px !important;
    padding: 8px 16px !important;
    width: auto !important;

    /* Visual */
    border-radius: 8px !important;
    border: 1px solid rgba(255, 255, 255, 0.00) !important;
    background: #3C6DD0 !important;
    background-color: #3C6DD0 !important;
    color: #ffffff !important;
    box-shadow: none !important;

    /* Typography */
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    line-height: 20px !important;
    text-transform: none !important;
    letter-spacing: normal !important;

    cursor: pointer !important;
    transition: background-color 0.2s ease !important;
}

/* SVG arrow derecha */
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions .zp-auth-form-button.zp-button.zp-button-primary::after,
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper button.zp-auth-form-button.zp-button.zp-button-primary::after,
.zp-auth-form .zp-auth-form-wrapper button.zp-button-primary.zp-auth-form-button::after {
    content: "" !important;
    width: 20px !important;
    height: 20px !important;
    display: inline-block !important;
    background-color: currentColor !important;
    mask: url('data:image/svg+xml;utf8,<svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M3.33334 10H16.6667M16.6667 10L10 3.33337M16.6667 10L10 16.6667" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>') no-repeat center !important;
    -webkit-mask: url('data:image/svg+xml;utf8,<svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M3.33334 10H16.6667M16.6667 10L10 3.33337M16.6667 10L10 16.6667" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>') no-repeat center !important;
    mask-size: contain !important;
    -webkit-mask-size: contain !important;
    flex-shrink: 0 !important;
}

/* Hover */
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions .zp-auth-form-button.zp-button.zp-button-primary:hover,
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper button.zp-auth-form-button.zp-button.zp-button-primary:hover,
.zp-auth-form .zp-auth-form-wrapper button.zp-button-primary.zp-auth-form-button:hover {
    background-color: #5488F0 !important;
    background: #5488F0 !important;
    color: #ffffff !important;
}

/* Active */
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions .zp-auth-form-button.zp-button.zp-button-primary:active,
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper button.zp-auth-form-button.zp-button.zp-button-primary:active,
.zp-auth-form .zp-auth-form-wrapper button.zp-button-primary.zp-auth-form-button:active {
    background-color: #3a5fb8 !important;
    background: #3a5fb8 !important;
}

/* Focus */
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions .zp-auth-form-button.zp-button.zp-button-primary:focus-visible,
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper button.zp-auth-form-button.zp-button.zp-button-primary:focus-visible,
.zp-auth-form .zp-auth-form-wrapper button.zp-button-primary.zp-auth-form-button:focus-visible {
    outline: none !important;
    background-color: #5488F0 !important;
    background: #5488F0 !important;
    border: 4px solid rgba(84, 136, 240, 0.3) !important;
}

/* Disabled */
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions .zp-auth-form-button.zp-button.zp-button-primary:disabled,
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper button.zp-auth-form-button.zp-button.zp-button-primary:disabled,
.zp-auth-form .zp-auth-form-wrapper button.zp-button-primary.zp-auth-form-button:disabled {
    background-color: #B9D0FF !important;
    background: #B9D0FF !important;
    color: #ffffff !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
    opacity: 1 !important;
}

.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions .zp-auth-form-button.zp-button.zp-button-primary:disabled::after,
.zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper button.zp-auth-form-button.zp-button.zp-button-primary:disabled::after,
.zp-auth-form .zp-auth-form-wrapper button.zp-button-primary.zp-auth-form-button:disabled::after {
    opacity: 0.7 !important;
}

/* Responsive - Small devices */
@media (max-width: 768px) {
    .zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions .zp-auth-form-button.zp-button.zp-button-primary,
    .zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper button.zp-auth-form-button.zp-button.zp-button-primary,
    .zp-auth-form .zp-auth-form-wrapper button.zp-button-primary.zp-auth-form-button {
        height: 40px !important;
        min-width: 120px !important;
    }
    
    .zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions .zp-auth-form-button.zp-button.zp-button-primary::after,
    .zp-sign-in-wrapper .zp-auth-form .zp-auth-form-wrapper button.zp-auth-form-button.zp-button.zp-button-primary::after,
    .zp-auth-form .zp-auth-form-wrapper button.zp-button-primary.zp-auth-form-button::after {
        width: 16px !important;
        height: 16px !important;
    }
}

/* ============================================
   ERROR MESSAGES
============================================ */
.zp-auth-form-error {
    color: #dc2626;
    font-size: 14px;
    margin-top: 12px;
    display: none;
}

.zp-auth-form-error:not(:empty) {
    display: block;
}

/* ============================================
   MULTI-STEP FORM (SIGN UP)
============================================ */
.zp-auth-form-first-form,
.zp-auth-form-second-form,
.zp-auth-form-third-form {
    display: none;
}

.zp-auth-form-first-form.active,
.zp-auth-form-second-form.active,
.zp-auth-form-third-form.active {
    display: block;
}

.zp-auth-form-privacy-message {
    margin-top: 16px;
    padding: 16px;
    background-color: #f9fafb;
    border-radius: 8px;
    font-size: 12px;
    color: #666;
    line-height: 1.5;
}
/* Alinear contenedor de botones a la derecha */
.zp-auth-form-actions-row {
    display: flex !important;
    gap: 12px !important;
    justify-content: flex-end !important;
}


/* ============================================
   ACCESS REQUEST SUBMITTED SCREEN
============================================ */
.zp-auth-form-submitted {
    display: none;
}

.zp-auth-form-submitted.active {
    display: block;
}

.zp-auth-form-submitted .zp-auth-form-body p {
    margin: 0;
}

.zp-auth-form-submitted .zp-auth-form-actions {
    margin-top: 32px;
}

.zp-auth-form-submitted .zp-button-secondary {
    width: 100%;
}


.zp-auth-password-toggle {
	border: none !important;
	outline: none !important;
}

.zp-auth-form-controls-password input {
	border: 1px solid #E2E8F0 !important;
}

.zp-button-primary.zp-button-no-arrow::after {
	display: none !important;
}

.zp-auth-form-privacy-message {
	margin-top: 32px;
	color: #64748B;
	font-family: Inter, Arial, sans-serif;
	font-size: 16px;
	font-weight: 400;
	line-height: 150%;
	letter-spacing: -0.16px;
	padding: 0;
	background-color: transparent;
	border-radius: 0;
}

.zp-auth-form-privacy-message p {
	margin-bottom: 0;
}

.zp-auth-form-privacy-message a {
	color: #3C6DD0;
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color 0.3s;
}

.zp-auth-form-privacy-message a:hover {
	border-color: #3C6DD0;
}

/* Access notice styling */
.zp-auth-access-notice {
	color: #0969DA;
	font-family: Inter, Arial, sans-serif;
	font-size: 14px;
	font-weight: 400;
	line-height: 150%;
	letter-spacing: -0.14px;
}

.zp-auth-access-notice p {
	margin: 0;
}


/* Quitar hover/outline del password toggle */
.zp-auth-password-toggle:hover,
.zp-auth-password-toggle:focus,
.zp-auth-password-toggle:active {
	background: none !important;
	outline: none !important;
	box-shadow: none !important;
	border: none !important;
}

/* Botón Back - Alineación y estilos */
.zp-auth-form-actions-row {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	gap: 12px !important;
}

.zp-auth-form-actions-back.zp-button-secondary {
	display: flex !important;
	width: 168px !important;
	height: 50px !important;
	padding: 8px 16px !important;
	justify-content: center !important;
	align-items: center !important;
	gap: 10px !important;
	border-radius: 8px !important;
	border: 1px solid #CBD5E1 !important;
	background: transparent !important;
	color: #020617 !important;
	box-shadow: none !important;
	margin-left: 0 !important;
	margin-right: auto !important;
}

.zp-auth-form-actions-back.zp-button-secondary:hover {
	background: #F1F5F9 !important;
	border: 1px solid #CBD5E1 !important;
}

/* Flecha antes del texto en botón Back */
.zp-auth-form-actions-back.zp-button-secondary::before {
	content: "" !important;
	width: 20px !important;
	height: 20px !important;
	flex-shrink: 0 !important;
	display: inline-block !important;
	background-color: currentColor !important;
	mask: url('data:image/svg+xml;utf8,<svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M10.0003 15.8334L4.16699 10.0001M4.16699 10.0001L10.0003 4.16675M4.16699 10.0001H15.8337" stroke="%23020617" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>') no-repeat center !important;
	-webkit-mask: url('data:image/svg+xml;utf8,<svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M10.0003 15.8334L4.16699 10.0001M4.16699 10.0001L10.0003 4.16675M4.16699 10.0001H15.8337" stroke="%23020617" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>') no-repeat center !important;
	mask-size: contain !important;
	-webkit-mask-size: contain !important;
}

/* Quitar flecha ::after si existe en secondary */
.zp-auth-form-actions-back.zp-button-secondary::after {
	display: none !important;
}

/* Fix para botones primary en form-reset-password y form-successfully-reset */
.zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions-row .zp-auth-form-button.zp-button-primary,
.zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions-row button.zp-button-primary,
.zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions-row a.zp-button-primary {
    display: flex !important;
    width: 168px !important;
    height: 50px !important;
    padding: 8px 16px !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 10px !important;
    border-radius: 8px !important;
    background: #3C6DD0 !important;
    background-color: #3C6DD0 !important;
    color: #ffffff !important;
    border: 1px solid transparent !important;
    box-shadow: none !important;
    font-family: Inter, Arial, sans-serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    line-height: 20px !important;
    text-decoration: none !important;
    cursor: pointer !important;
}

.zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions-row .zp-auth-form-button.zp-button-primary:hover,
.zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions-row button.zp-button-primary:hover,
.zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions-row a.zp-button-primary:hover {
    background: #5488F0 !important;
    background-color: #5488F0 !important;
}

.zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions-row .zp-auth-form-button.zp-button-primary:disabled,
.zp-auth-form .zp-auth-form-wrapper .zp-auth-form-actions-row button.zp-button-primary:disabled {
    background: #B9D0FF !important;
    background-color: #B9D0FF !important;
    cursor: not-allowed !important;
}


/* Cuando solo hay UN botón en la fila, alinearlo a la derecha */
.zp-auth-form-actions-row:has(> :only-child) {
	justify-content: flex-end !important;
}

/* O si el navegador no soporta :has(), usar esto como alternativa */
.zp-auth-form-actions-row > .zp-auth-form-button:only-child {
	margin-left: auto !important;
}

/* ============================================
   ACCORDION
============================================ */
.zp-auth-accordion {
	display: flex;
	padding: 12px 16px;
	flex-direction: column;
	align-items: flex-start;
	gap: 8px;
	align-self: stretch;
	border-radius: 12px;
	background: #EFF4FF;
	margin-top: 24px;
}

.zp-auth-accordion-header {
	display: flex;
	align-items: center;
	align-self: stretch;
	width: 100%;
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
	transition: opacity 0.2s ease;
}

.zp-auth-accordion-header:hover {
	opacity: 0.8;
}

.zp-auth-accordion-title {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 6px;
	width: 100%;
	color: #020617;
	font-family: Inter, Arial, sans-serif;
	font-size: 18px;
	font-weight: 500;
	line-height: 150%;
	letter-spacing: -0.18px;
	text-align: left;
}

.zp-auth-accordion-title svg:first-child {
	flex-shrink: 0;
}

.zp-auth-accordion-icon {
	flex-shrink: 0;
	margin-left: auto;
	transition: transform 0.3s ease;
}

.zp-auth-accordion.active .zp-auth-accordion-icon {
	transform: rotate(180deg);
}

.zp-auth-accordion-content {
	display: none;
	color: #334155;
	font-family: Inter, Arial, sans-serif;
	font-size: 14px;
	font-weight: 400;
	line-height: 150%;
	letter-spacing: -0.14px;
	padding-top: 8px;
}

.zp-auth-accordion.active .zp-auth-accordion-content {
	display: block;
}

.zp-auth-accordion-content p {
	margin: 0 0 12px 0;
}

.zp-auth-accordion-content p:last-child {
	margin-bottom: 0;
}

.zp-auth-accordion-content a {
	color: #3C6DD0;
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color 0.3s;
}

.zp-auth-accordion-content a:hover {
	border-color: #3C6DD0;
}

/* Accordion sin hover y sin borde */
.zp-auth-accordion-header {
	border: none !important;
	outline: none !important;
}

.zp-auth-accordion-header:hover {
	opacity: 1 !important;
	background: none !important;
}

/* Quitar recuadro rosa/rojo del accordion header */
.zp-auth-accordion-header:focus,
.zp-auth-accordion-header:focus-visible,
.zp-auth-accordion-header:focus-within {
	outline: none !important;
	box-shadow: none !important;
	background: none !important;
	border: none !important;
}

.zp-auth-accordion-header:hover,
.zp-auth-accordion-header:active {
	outline: none !important;
	box-shadow: none !important;
	background: transparent !important;
	border: none !important;
}

/* Quitar cualquier estilo de focus del accordion completo */
.zp-auth-accordion:focus-within {
	outline: none !important;
	box-shadow: none !important;
}

/* Password Requirements */
.zp-password-requirements {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.zp-password-req {
	display: flex;
	align-items: center;
	gap: 8px;
	color: #64748B;
	font-size: 14px;
	line-height: 1.5;
	transition: color 0.2s ease;
}

.zp-password-req.valid {
	color: #10B981;
}

.zp-password-req-icon {
	font-weight: 700;
	min-width: 16px;
}