/* ==========================================================================
   TIPOMAP.LAT - Admin Authentication Styles (Swiss Design)
   Consolidated for: index.php, forgot_password.php, reset_password.php
   ========================================================================== */

:root {
    --bg-off-white: #f9f7f2;
    --text-black: #000;
    --success-color: #27ae60;
    --danger-color: #ff4b2b;
    --grey-color: #666;
    --light-grey: #999;
}

body.login-page, 
body.login-page h1, 
body.login-page h2, 
body.login-page p, 
body.login-page label, 
body.login-page a, 
body.login-page button, 
body.login-page input {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif !important;
}

body.login-page {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background-color: var(--bg-off-white);
    margin: 0;
    padding: 20px;
}

.login-card {
    width: 100%;
    max-width: 450px;
    padding: 4rem;
    background: #fff;
    border: 1px solid #000;
    position: relative;
    box-sizing: border-box;
}

.login-card__title {
    font-size: 2.8rem;
    font-weight: 800;
    text-transform: lowercase;
    letter-spacing: -0.02em;
    margin: 0;
    line-height: 1;
}

.login-card__subtitle {
    font-size: 0.65rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--grey-color);
    margin-top: 0.5rem;
    margin-bottom: 3.5rem;
}

.form-group {
    margin-bottom: 1.8rem;
}

.tech-label {
    display: block;
    font-size: 0.6rem;
    color: #000;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 0.6rem;
}

.form-control {
    border-radius: 0 !important;
    border: 1px solid #bcbcbc !important;
    padding: 12px !important;
    width: 100% !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    background: transparent !important;
    transition: all 0.2s ease;
    box-sizing: border-box;
}

.form-control:focus {
    border-color: #000 !important;
    outline: none !important;
    box-shadow: inset 0 0 0 1px #000 !important;
}

.btn-swiss {
    width: 100%;
    padding: 1.2rem;
    font-size: 0.75rem;
    background: #000;
    color: #fff;
    border: none;
    cursor: pointer;
    text-transform: uppercase;
    font-weight: 800;
    letter-spacing: 0.15em;
    transition: all 0.2s ease;
    margin-top: 1rem;
}

.btn-swiss:hover {
    background: #333;
}

.alert {
    font-size: 0.7rem;
    border-radius: 0;
    padding: 1.2rem 1.5rem;
    margin-bottom: 2.5rem;
    line-height: 1.6;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border: 1px solid #000;
    background: #fff;
    display: block;
    box-sizing: border-box;
}

.alert-danger { 
    border-left: 12px solid var(--danger-color);
    color: #000;
}

.alert-success { 
    border-left: 12px solid var(--success-color);
    color: #000;
}

.login-footer {
    margin-top: 4rem;
    text-align: center;
    border-top: 1px solid #eee;
    padding-top: 2rem;
}

.login-footer--flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.login-footer a {
    font-size: 0.6rem;
    text-decoration: none;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--light-grey);
    transition: color 0.2s ease;
}

.login-footer a:hover {
    color: #000;
}
