:root {
    /* Variáveis padrão (serão sobrescritas pelo inline CSS do admin) */
    --csl-auth-title: #1e293b;
    --csl-auth-subtitle: #64748b;
    --csl-auth-label: #1e293b;
    --csl-auth-primary: #7c3aed;
    --csl-auth-btn-text: #ffffff;
    --csl-auth-in-bg: #ffffff;
    --csl-auth-border: rgba(0, 0, 0, 0.1);
    --csl-auth-icon: #64748b;
}

.csl-auth-wrapper {
    padding: 20px !important;
    width: 100% !important;
    background: transparent !important;
    display: flex;
    justify-content: center;
    align-items: center;
}

.csl-auth-grid {
    display: flex !important;
    flex-direction: row !important;
    max-width: none !important;
    width: 100% !important;
    background: #ffffff !important;
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.05) !important;
    overflow: hidden;
}

.csl-auth-column {
    flex: 1;
    min-width: 320px;
    padding: 40px;
    transition: all 0.3s ease;
}

.csl-auth-header { margin-bottom: 30px; text-align: center; }

.csl-auth-header h2 { 
    font-size: 28px !important; 
    font-weight: inherit !important; 
    color: var(--csl-auth-title) !important; 
    margin: 0 0 8px 0 !important; 
    border: none !important; 
}

.csl-auth-header p { 
    font-size: 16px !important; 
    color: var(--csl-auth-subtitle) !important; 
}

.csl-auth-form { display: grid !important; gap: 20px !important; }

.csl-auth-field label {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--csl-auth-label) !important;
    margin-bottom: 5px !important;
}

.csl-auth-input-wrap {
    position: relative !important;
    width: 100% !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
}

.csl-auth-input-wrap i { 
    position: absolute !important; 
    left: 18px !important; 
    top: 50% !important; 
    transform: translateY(-50%) !important; 
    color: var(--csl-auth-icon) !important; 
    font-size: 17px !important; 
}

.csl-auth-input-wrap input {
    width: 100% !important;
    height: 54px !important;
    padding: 0 50px !important;
    border: 1.5px solid #cbd5e1 !important;
    border-radius: 12px !important;
    background: var(--csl-auth-in-bg) !important;
    color: var(--csl-auth-title) !important;
    font-size: 15px !important;
    transition: all 0.3s ease !important;
}

.csl-auth-input-wrap input:focus {
    border-color: var(--csl-auth-primary) !important;
    box-shadow: 0 0 0 4px rgba(124, 58, 237, 0.1) !important;
    outline: none !important;
}

/* Specific fix for password toggle button */
button.csl-auth-toggle-pass,
.csl-auth-input-wrap button.csl-auth-toggle-pass {
    position: absolute !important;
    right: 15px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    background: none !important;
    background-color: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 30px !important;
    height: 30px !important;
    cursor: pointer !important;
    color: var(--csl-auth-icon) !important;
    font-size: 18px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 10 !important;
    box-shadow: none !important;
    min-height: unset !important;
    line-height: 1 !important;
}

button.csl-auth-toggle-pass:hover {
    color: var(--csl-auth-primary) !important;
    background: none !important;
}

/* Toggle Switch */
.csl-auth-slider { background-color: #e2e8f0 !important; }
.csl-auth-switch input:checked + .csl-auth-slider { background-color: var(--csl-auth-primary) !important; }

/* Buttons */
.csl-auth-btn-submit {
    flex: 1;
    background: var(--csl-auth-primary) !important;
    color: var(--csl-auth-btn-text) !important;
    height: 54px !important;
    border-radius: 12px !important;
    font-weight: 700 !important;
    border: none !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.csl-auth-actions-group {
    display: flex !important;
    gap: 15px !important;
    align-items: center !important;
}

.csl-auth-social {
    flex: 1;
    margin: 0 !important;
}

.csl-auth-social .csl-social-auth-btns a,
.csl-auth-social .csl-social-auth-btn {
    width: 100% !important;
    height: 54px !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.csl-auth-link {
    font-weight: 600 !important;
    text-decoration: none !important;
    font-size: 14px !important;
}

.csl-auth-remember {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 5px !important;
}

.csl-auth-switch-label {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    cursor: pointer !important;
    margin: 0 !important;
}

.csl-auth-switch-text {
    font-size: 14px !important;
    color: var(--csl-auth-subtitle) !important;
    white-space: nowrap !important;
}

.csl-auth-v-divider { align-self: stretch; background: rgba(0,0,0,0.1); width: 1px; margin: 20px 0; }

/* Social Auth Pill Buttons - Very Aggressive */
.csl-social-auth-btns a, 
.csl-social-auth-btn,
.csl-social-auth-btns .csl-auth-btn,
div.csl-social-auth-btns a {
    border-radius: 50px !important;
    padding-left: 25px !important;
    padding-right: 25px !important;
}

@media (max-width: 900px) {
    .csl-auth-grid { flex-direction: column; flex-wrap: wrap; }
    .csl-auth-v-divider { height: 1px; width: 100%; margin: 10px 0; }
    .csl-auth-column { padding: 30px 20px; min-width: 100%; }
}
