:root{
    --primary:#28a8d4;
    --primary-dark:#1e7da0;
    --text:#444;
    --bg:#f5f7f9;
}

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

body{
    font-family:'Open Sans',system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    background:var(--bg);
    color:var(--text);
}

/* Page layout */
.login-page{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:1.5rem;
}

/* Card */
.login-card{
    width:100%;
    max-width:420px;
    background:#fff;
    border-radius:14px;
    box-shadow:0 18px 45px rgba(0,0,0,0.08);
    padding:2.2rem 2.3rem 2rem;
}

/* Header */
.login-header h1{
    font-family:'Playfair Display',serif;
    font-size:1.8rem;
    color:var(--primary);
    text-align:center;
    margin-bottom:0.4rem;
}

.login-header p{
    font-size:0.9rem;
    text-align:center;
    color:#777;
    margin-bottom:1.6rem;
}

/* Form */
.login-form{
    display:flex;
    flex-direction:column;
    gap:1rem;
}

.form-group{
    display:flex;
    flex-direction:column;
    gap:0.25rem;
}

.form-group label{
    font-size:0.85rem;
    font-weight:600;
    color:#666;
}

.form-group input{
    padding:0.6rem 0.8rem;
    border-radius:8px;
    border:1px solid #d1d5db;
    font-size:0.9rem;
    transition:border-color 0.2s, box-shadow 0.2s;
}

.form-group input:focus{
    outline:none;
    border-color:var(--primary);
    box-shadow:0 0 0 2px rgba(40,168,212,0.15);
}

/* Remember + forgot */
.form-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    font-size:0.85rem;
    margin-top:0.2rem;
}

.remember{
    display:flex;
    align-items:center;
    gap:0.3rem;
    cursor:pointer;
}

.remember input{
    width:14px;
    height:14px;
}

.forgot{
    color:var(--primary-dark);
}

/* Button */
.btn-login{
    margin-top:0.8rem;
    width:100%;
    padding:0.65rem 1rem;
    border:none;
    border-radius:999px;
    background:var(--primary);
    color:#fff;
    font-size:0.95rem;
    font-weight:600;
    cursor:pointer;
    transition:background 0.2s, transform 0.1s, box-shadow 0.2s;
}

.btn-login:hover{
    background:var(--primary-dark);
    box-shadow:0 10px 25px rgba(40,168,212,0.35);
}

.btn-login:active{
    transform:scale(0.97);
}

/* Footer text */
.login-footer{
    margin-top:1.5rem;
    text-align:center;
    font-size:0.85rem;
    color:#777;
}

.login-footer a{
    color:var(--primary-dark);
}

/* Responsive */
@media (max-width:480px){
    .login-card{
        padding:1.7rem 1.5rem 1.6rem;
    }

    .login-header h1{
        font-size:1.6rem;
    }
}
