:root { --dms: #1c6b7a; --dms-dark: #155a68; --dms-mid: #3a8fa0; }

* { box-sizing: border-box; }
body { margin: 0; background: #e8ecee; font-family: 'Segoe UI', Arial, sans-serif; }

.login-hero {
    background: var(--dms);
    padding: 2.8rem 1rem 5rem;
    text-align: center;
}
.login-hero h1 { color: #fff; font-size: 2rem; font-weight: 400; margin: 0; }

.login-wrap {
    display: flex;
    justify-content: center;
    margin-top: -3.2rem;
    padding: 0 1rem 3rem;
}

.login-card {
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0,0,0,.14);
    padding: 2rem 2.2rem 1.8rem;
    width: 100%;
    max-width: 420px;
}
.login-card h2       { font-size: 1.25rem; font-weight: 600; text-align: center; margin-bottom: .3rem; color: #1a1a1a; }
.login-card .subtitle { font-size: .82rem; color: #666; text-align: center; margin-bottom: 1.4rem; }

.input-row {
    display: flex;
    align-items: center;
    border: 1px solid #ccc;
    border-radius: 4px;
    margin-bottom: .75rem;
    overflow: hidden;
}
.input-row .icon {
    background: #f4f4f4;
    border-right: 1px solid #ccc;
    padding: .5rem .75rem;
    color: #555;
    font-size: .95rem;
    display: flex;
    align-items: center;
}
.input-row input {
    border: none; outline: none; flex: 1;
    padding: .5rem .65rem; font-size: .9rem; color: #222; background: transparent;
}
.input-row .eye-btn {
    background: none; border: none; padding: .5rem .7rem;
    color: #777; cursor: pointer; font-size: .95rem; display: flex; align-items: center;
}
.input-row .eye-btn:hover { color: var(--dms); }

.input-label { font-size: .8rem; color: #555; margin-bottom: .25rem; padding-left: .1rem; }

.btn-login {
    display: block; width: 100%;
    background: var(--dms); color: #fff; border: none; border-radius: 4px;
    padding: .65rem 1rem; font-size: .95rem; font-weight: 600;
    cursor: pointer; margin-top: 1.1rem; transition: background .15s;
}
.btn-login:hover { background: var(--dms-dark); }

.btn-register {
    display: block; width: 100%;
    background: var(--dms-mid); color: #fff; border: none; border-radius: 4px;
    padding: .55rem 1rem; font-size: .88rem;
    margin-top: .55rem; text-align: center; cursor: pointer; transition: background .15s;
}
.btn-register:hover { background: var(--dms); }

.btn-reg-cancel {
    background: #aaa; color: #fff; border: none; border-radius: 4px;
    padding: .4rem .9rem; font-size: .88rem; cursor: pointer;
}
.btn-reg-cancel:hover { background: #888; color: #fff; }
.btn-reg-submit {
    background: #1c6b7a; color: #fff; border: none; border-radius: 4px;
    padding: .4rem 1rem; font-size: .88rem; cursor: pointer; transition: background .15s;
}
.btn-reg-submit:hover  { background: #155a68; }
.btn-reg-submit:disabled { opacity: .65; cursor: default; }

.alert-login {
    background: #fdecea; border: 1px solid #f5c2c2; color: #8b1a1a;
    border-radius: 4px; padding: .55rem .8rem; font-size: .85rem; margin-bottom: .9rem;
}
