.escola-auth-wrap {
    padding: 2rem 0 3rem;
}

.escola-auth-hero {
    background: linear-gradient(135deg, #0f2344 0%, #1b3a6b 50%, #1e73e8 100%);
    color: #fff;
    border-radius: 18px;
    padding: 1.2rem 1.4rem;
    box-shadow: 0 14px 28px rgba(15, 35, 68, 0.2);
    margin-bottom: 1.2rem;
}

.escola-auth-title {
    margin: 0;
    font-weight: 800;
    font-size: clamp(1.3rem, 2.1vw, 2rem);
}

.escola-auth-subtitle {
    margin: .35rem 0 0;
    color: #d9e9ff;
}

.escola-auth-card {
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid #d8e6fb;
    border-radius: 16px;
    box-shadow: 0 14px 28px rgba(15, 23, 42, .1);
    overflow: hidden;
}

.escola-auth-card .card-body {
    padding: 2rem;
}

.escola-auth-label {
    font-weight: 700;
    color: #123a72;
    margin-bottom: .4rem;
}

.escola-auth-input {
    border: 1px solid #cfe0f7;
    border-radius: 10px;
    background: #f9fbff;
    min-height: 46px;
}

.escola-auth-input:focus {
    border-color: #1e73e8;
    box-shadow: 0 0 0 0.2rem rgba(30, 115, 232, .15);
    background: #fff;
}

.escola-auth-primary {
    background: linear-gradient(135deg, #1b3a6b, #1e73e8 60%, #19b4cf);
    border: none;
    color: #fff;
    border-radius: 10px;
    font-weight: 700;
    min-height: 44px;
}

.escola-auth-primary:hover {
    color: #fff;
    background: linear-gradient(135deg, #0f2344, #1b4f96 60%, #14899d);
}

.escola-auth-secondary {
    border: 1px solid #c7d9f5;
    color: #1b3a6b;
    border-radius: 10px;
    font-weight: 700;
    min-height: 44px;
    background: #fff;
}

.escola-auth-secondary:hover {
    background: #edf4ff;
    color: #0f2344;
}

.escola-auth-link {
    color: #1e73e8;
    font-weight: 700;
    text-decoration: none;
}

.escola-auth-link:hover {
    color: #124b97;
    text-decoration: underline;
}
