*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

body{
    font-family:'Segoe UI',sans-serif;
    background:#eef3f0;
    min-height:100vh;
}

/* =========================================
   LAYOUT
========================================= */

.login-premium{
    min-height:100vh;

    display:flex;
    align-items:center;
    justify-content:center;

    padding:40px;
}

.login-premium-shell{
    width:100%;
    max-width:1700px;

    position:relative;
}

/* =========================================
   BOTON VOLVER
========================================= */

.login-back{
    position:absolute;

    top:24px;
    left:24px;

    z-index:40;

    display:flex;
    align-items:center;
    gap:10px;

    padding:16px 24px;

    border-radius:999px;

    text-decoration:none;

    color:#fff;

    background:
        rgba(255,255,255,.16);

    backdrop-filter:blur(14px);

    border:
        1px solid rgba(255,255,255,.14);

    transition:.3s ease;
}

.login-back:hover{
    transform:translateY(-2px);

    background:
        rgba(255,255,255,.22);
}

.login-back svg{
    width:22px;
    height:22px;

    stroke:currentColor;
    stroke-width:2;
    fill:none;
}

/* =========================================
   CARD PRINCIPAL
========================================= */

.login-premium-card{
    display:grid;

    grid-template-columns:30% 70%;

    min-height:min(760px, 90vh);

    overflow:hidden;

    border-radius:42px;

    background:#fff;

    box-shadow:
        0 30px 80px rgba(16,52,42,.12);
}

/* =========================================
   PANEL IZQUIERDO
========================================= */

.login-visual-panel{
    position:relative;

    background:
        linear-gradient(
            rgba(0,0,0,.38),
            rgba(0,0,0,.48)
        ),
        url("https://images.unsplash.com/photo-1506744038136-46273834b3fb?auto=format&fit=crop&w=1600&q=80");

    background-size:cover;
    background-position:center;

    display:flex;
    align-items:center;
    justify-content:center;

    padding:40px;
}

.login-overlay{
    position:absolute;
    inset:0;

    background:
        linear-gradient(
            180deg,
            rgba(0,0,0,.08),
            rgba(0,0,0,.45)
        );
}

.login-visual-content{
    position:relative;
    z-index:2;

    color:#fff;
}

.login-brand{
    margin-bottom:60px;

    text-align:center;
}

.login-brand span{
    display:block;

    margin-bottom:10px;

    font-size:38px;

    font-weight:800;

    letter-spacing:4px;
}

.login-brand small{
    font-size:14px;

    letter-spacing:2px;

    color:rgba(255,255,255,.82);
}

.login-hero-text h1{
    margin-bottom:18px;

    font-size:52px;

    line-height:1;

    font-family:Georgia,serif;

    font-weight:700;

    text-align:center;
}

.login-hero-text p{
    max-width:320px;

    margin:auto;

    text-align:center;

    font-size:18px;

    line-height:1.7;

    color:rgba(255,255,255,.88);
}

/* =========================================
   PANEL DERECHO
========================================= */

.login-form-panel{
    display:flex;
    align-items:center;
    justify-content:center;

    padding:60px 80px;
}

.login-form-inner{
    width:100%;
    max-width:620px;
}

.login-heading{
    margin-bottom:44px;
}

.login-heading h2{
    margin-bottom:14px;

    font-size:58px;

    line-height:1;

    color:#173029;

    font-family:Georgia,serif;
}

.login-heading p{
    color:#70807a;

    font-size:20px;

    line-height:1.6;
}

/* =========================================
   FORM
========================================= */

.premium-login-form{
    display:flex;
    flex-direction:column;
    gap:28px;
}

.google-auth-btn{
    width:100%;
    min-height:58px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    margin-bottom:22px;
    border:1px solid rgba(18,54,44,.14);
    border-radius:18px;
    color:#173029;
    background:#fff;
    font-weight:800;
}

.google-auth-btn span{
    display:grid;
    place-items:center;
    width:28px;
    height:28px;
    border-radius:50%;
    color:#fff;
    background:#173029;
}

.google-auth-btn:disabled{
    opacity:.72;
    cursor:not-allowed;
}

.auth-divider{
    display:flex;
    align-items:center;
    gap:12px;
    margin-bottom:22px;
    color:#6f817a;
    font-size:13px;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:1px;
}

.auth-divider::before,
.auth-divider::after{
    content:"";
    flex:1;
    height:1px;
    background:rgba(18,54,44,.12);
}

.premium-field label{
    display:block;

    margin-bottom:14px;

    color:#173029;

    font-size:16px;

    font-weight:700;
}

.premium-input-wrap{
    display:flex;
    align-items:center;
    gap:16px;

    height:76px;

    padding:0 24px;

    border-radius:24px;

    background:#fff;

    border:
        1px solid rgba(18,54,44,.14);

    transition:.3s ease;
}

.premium-input-wrap:focus-within{
    border-color:#02634f;

    box-shadow:
        0 0 0 4px rgba(2,99,79,.08);
}

.premium-input-wrap svg{
    width:22px;
    height:22px;

    stroke:#6d8078;
    stroke-width:2;
    fill:none;

    flex-shrink:0;
}

.premium-input-wrap input{
    flex:1;

    border:none;
    outline:none;
    background:transparent;

    font-size:18px;

    color:#173029;
}

.premium-input-wrap input::placeholder{
    color:#9aa7a2;
}

.password-toggle{
    border:none;
    background:none;

    display:flex;
    align-items:center;
    justify-content:center;

    cursor:pointer;
}

/* =========================================
   TEXTO MINI
========================================= */

.login-mini-text{
    margin-top:-4px;
}

.login-mini-text p{
    color:#73827c;

    line-height:1.7;
}

/* =========================================
   BOTON LOGIN
========================================= */

.premium-submit{
    margin-top:10px;

    height:76px;

    border:none;

    border-radius:24px;

    background:
        linear-gradient(
            135deg,
            #014034,
            #02634f
        );

    color:#fff;

    display:flex;
    align-items:center;
    justify-content:space-between;

    padding:0 28px;

    font-size:20px;
    font-weight:800;

    cursor:pointer;

    transition:.3s ease;

    box-shadow:
        0 18px 36px rgba(1,64,52,.18);
}

.premium-submit:hover{
    transform:translateY(-3px);
}

.premium-submit svg{
    width:22px;
    height:22px;

    stroke:#fff;
    stroke-width:2;
    fill:none;
}

/* =========================================
   FOOTER
========================================= */

.premium-login-footer{
    margin-top:40px;

    display:flex;
    flex-direction:column;
    gap:18px;
}

.premium-login-footer p{
    color:#6f817a;
}

.premium-login-footer a{
    color:#02634f;

    font-weight:700;

    text-decoration:none;
}

.recover-link{
    width:max-content;
}

/* =========================================
   MENSAJES
========================================= */

.premium-login-message{
    margin-top:28px;

    padding:16px 18px;

    border-radius:18px;

    font-weight:600;

    display:none;
}

.premium-login-message.show{
    display:block;
}

.premium-login-message.success{
    background:#e9f8f0;
    color:#02634f;
}

.premium-login-message.error{
    background:#fdeceb;
    color:#b42318;
}

.login-spinner{
    width:20px;
    height:20px;
    border:3px solid rgba(255,255,255,.28);
    border-top-color:#fff;
    border-radius:50%;
    animation:spin .8s linear infinite;
}

@keyframes spin{
    to{ transform:rotate(360deg); }
}

/* =========================================
   RESPONSIVE
========================================= */

@media(max-width:1200px){

    .login-premium-card{
        grid-template-columns:1fr;
    }

    .login-visual-panel{
        min-height:420px;
    }
}

@media(max-width:768px){

    .login-premium{
        padding:18px;
    }

    .login-form-panel{
        padding:40px 26px;
    }

    .login-heading h2{
        font-size:52px;
    }

    .login-hero-text h1{
        font-size:54px;
    }

    .login-brand span{
        font-size:44px;
    }

    .login-visual-panel{
        padding:40px 28px;
    }

    .premium-submit{
        font-size:18px;
    }
}
/* =========================================
   MODALES
========================================= */

.auth-action-btn{
    border:none;
    background:none;
    color:#02634f;
    font-weight:700;
    cursor:pointer;
    text-align:left;
    width:max-content;
}

.auth-action-btn:hover{
    text-decoration:underline;
}

.auth-modal{
    position:fixed;
    inset:0;

    display:none;

    align-items:center;
    justify-content:center;

    background:rgba(0,0,0,.55);

    backdrop-filter:blur(8px);

    z-index:9999;
}

.auth-modal.show{
    display:flex;
}

.auth-modal-card{
    width:100%;
    max-width:580px;
    max-height:90vh;
    overflow-y:auto;

    background:#fff;

    border-radius:28px;

    padding:32px;

    position:relative;

    box-shadow:
        0 30px 80px rgba(0,0,0,.20);
}

.close-modal{
    position:absolute;

    top:18px;
    right:18px;

    border:none;
    background:none;

    font-size:28px;

    cursor:pointer;
}

.auth-modal-card h2{
    margin-bottom:20px;

    color:#173029;

    font-size:32px;
}

.auth-modal-form{
    display:flex;
    flex-direction:column;
    gap:16px;
}

.auth-modal-form input,
.auth-modal-form select{
    height:58px;

    border-radius:16px;

    border:1px solid rgba(18,54,44,.14);

    padding:0 18px;

    font-size:16px;
}

.auth-modal-form textarea{
    min-height:120px;

    border-radius:16px;

    border:1px solid rgba(18,54,44,.14);

    padding:16px;
}

.modal-submit{
    height:58px;

    border:none;

    border-radius:16px;

    background:
        linear-gradient(
            135deg,
            #014034,
            #02634f
        );

    color:#fff;

    font-weight:700;

    cursor:pointer;
}

/* =========================================
   MODAL CREAR CUENTA — MEJORADO
========================================= */

/* Card del modal de registro: más ancha, sin scroll en desktop */
.register-modal-card {
    width: 100%;
    max-width: 680px;
    /* Con overflow-y: auto para que no se desborde con zoom 100% */
    max-height: 90vh;
    overflow-y: auto;
    padding: 24px 30px;
}

/* Header con subtítulo */
.register-modal-header {
    margin-bottom: 22px;
}

.register-modal-header h2 {
    margin: 0 0 6px;
    color: #173029;
    font-size: 28px;
    font-weight: 800;
    font-family: Georgia, serif;
}

.register-modal-header p {
    margin: 0;
    color: #6d8078;
    font-size: 14px;
    line-height: 1.5;
}

/* Formulario en grid compacto */
.register-modal-form {
    gap: 14px !important;
}

/* Fila de 2 columnas */
.reg-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

/* Campo individual */
.reg-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.reg-field label {
    font-size: 13px;
    font-weight: 700;
    color: #3b5249;
    letter-spacing: 0.01em;
}

.req {
    color: #c0392b;
    font-weight: 900;
}

/* Inputs compactos */
.register-modal-form input,
.register-modal-form select {
    height: 48px !important;
    border-radius: 14px !important;
    border: 1px solid rgba(18, 54, 44, .14) !important;
    padding: 0 14px !important;
    font-size: 15px !important;
    transition: border-color .2s ease, box-shadow .2s ease !important;
    background: #fafcfb !important;
}

.register-modal-form input:focus {
    outline: none !important;
    border-color: #02634f !important;
    box-shadow: 0 0 0 3px rgba(2, 99, 79, .10) !important;
    background: #fff !important;
}

.register-modal-form input::placeholder {
    color: #9baca6;
    font-size: 14px;
}

/* Botón submit en el modal */
.register-modal-form .modal-submit {
    margin-top: 6px;
    font-size: 16px;
    letter-spacing: 0.02em;
    transition: transform .25s ease, box-shadow .25s ease;
}

.register-modal-form .modal-submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(1, 64, 52, .22);
}

.register-modal-form .modal-submit:disabled {
    opacity: .72;
    cursor: not-allowed;
    transform: none;
}

/* Mensaje feedback */
.modal-message {
    display: none;
    padding: 12px 16px;
    border-radius: 14px;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 14px;
    line-height: 1.5;
}

.modal-message--visible {
    display: block;
}

.modal-message--success {
    background: #e9f8f0;
    color: #02634f;
    border: 1px solid rgba(2, 99, 79, .18);
}

.modal-message--error {
    background: #fdeceb;
    color: #b42318;
    border: 1px solid rgba(180, 35, 24, .18);
}

/* Animación de entrada del modal */
.auth-modal {
    transition: opacity .2s ease;
}

.auth-modal-card {
    transform: translateY(16px);
    transition: transform .28s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.auth-modal.show .auth-modal-card {
    transform: translateY(0);
}

/* ── Responsive del modal ────────────────────────── */
@media (max-width: 720px) {
    .register-modal-card {
        padding: 28px 20px 24px;
        max-height: 92vh;
        overflow-y: auto;   /* solo en mobile pequeño activa scroll */
    }

    .reg-row {
        grid-template-columns: 1fr;   /* una columna en móvil */
    }
}

@media (max-width: 480px) {
    .auth-modal {
        padding: 12px;
    }

    .register-modal-card {
        border-radius: 20px;
        padding: 22px 16px 20px;
    }

    .register-modal-header h2 {
        font-size: 22px;
    }
}

/* =========================================
   COUNTRY DIAL PREFIX & SELECT (registro)
========================================= */

#registerForm select,
#registerForm select#regPais,
#registerForm select#regTipoDoc {
    width: 100%;
    height: 52px;
    padding: 0 14px;
    border-radius: 14px;
    border: 1.5px solid rgba(23, 48, 41, .13);
    background: #f7fbf9;
    font-size: 14px;
    font-weight: 600;
    color: #173029;
    cursor: pointer;
    appearance: auto;
    transition: border-color .2s, box-shadow .2s;
}

#registerForm select:focus {
    outline: none;
    border-color: #5e9e7e;
    box-shadow: 0 0 0 3px rgba(94, 158, 126, .12);
}

.reg-dial-prefix {
    display: inline-flex;
    align-items: center;
    min-height: 52px;
    padding: 0 12px;
    border-radius: 14px;
    border: 1.5px solid rgba(23, 48, 41, .13);
    background: #e8f0eb;
    font-size: 13px;
    font-weight: 700;
    color: #173029;
    white-space: nowrap;
    flex-shrink: 0;
    min-width: 56px;
    justify-content: center;
}

.reg-hint {
    display: block;
    font-size: 11px;
    color: #7a9088;
    margin-top: 4px;
}
