body {
    background-color: #f8f9fa;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

.auth-wrapper {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.auth-card {
    background-color: white;
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    width: 100%;
    max-width: 450px;
    padding: 40px;
    margin-top: 20px;
}

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

.auth-logo {
    height: 60px;
    margin-bottom: 20px;
}

.auth-title {
    font-size: 24px;
    font-weight: 600;
    color: #333;
    margin-bottom: 10px;
}

.auth-subtitle {
    font-size: 16px;
    color: #666;
}

/* PassJump Brand Logo */
.passjump-brand {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 20px;
}

.passjump-icon {
    width: 56px;
    height: 42px;
    color: #7c3aed;
}

.passjump-icon .arrow {
    color: #A3CC39;
}

.passjump-text {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.passjump-title {
    font-size: 2rem;
    font-weight: 700;
    color: #1f2937;
    letter-spacing: -0.02em;
}

.passjump-title .pass {
    color: #7c3aed;
}

.passjump-title .jump {
    color: #85B72A;
    font-style: italic;
}

.passjump-attribution {
    font-size: 0.7rem;
    color: #a1a1aa;
    font-weight: 400;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-align: center;
    margin-top: 8px;
    margin-bottom: 4px;
}

.form-group {
    margin-bottom: 20px;
}

.form-control {
    height: 48px;
    border-radius: 4px;
    border: 1px solid #ced4da;
    padding: 10px 15px;
    font-size: 16px;
}

.form-control:focus {
    border-color: #007bff; /* AtomicSchools Blue */
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

.btn-primary {
    background-color: #007bff;
    border-color: #007bff;
    height: 48px;
    font-size: 16px;
    font-weight: 500;
    width: 100%;
}

.btn-secondary {
    background-color: #6c757d;
    border-color: #6c757d;
    height: 48px;
    font-size: 16px;
    font-weight: 500;
    width: 100%;
}

/* PassJump Branding Overrides */
.passjump-theme .btn-primary {
    background-color: #7c3aed;
    border-color: #7c3aed;
}

.passjump-theme .btn-primary:hover {
    background-color: #6d28d9;
    border-color: #6d28d9;
}

.passjump-theme .form-control:focus {
    border-color: #7c3aed;
    box-shadow: 0 0 0 0.2rem rgba(124, 58, 237, 0.25);
}

/* Google Button */
.btn-google {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    background-color: white;
    color: #3c4043;
    border: 1px solid #dadce0;
    border-radius: 4px;
    height: 48px;
    width: 100%;
    font-weight: 500;
    font-size: 16px;
    text-decoration: none;
    transition: background-color 0.2s;
}

.btn-google:hover {
    background-color: #f8f9fa;
    border-color: #dadce0;
    color: #202124;
    text-decoration: none;
}

/* PassJack Brand Logo */
.passjack-brand {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}

.passjack-logo {
    height: 48px;
    width: auto;
}

/* PassJack Branding Overrides */
.passjack-theme .btn-primary {
    background-color: #FF4D00;
    border-color: #FF4D00;
}

.passjack-theme .btn-primary:hover {
    background-color: #E04400;
    border-color: #E04400;
}

.passjack-theme .form-control:focus {
    border-color: #0094A1;
    box-shadow: 0 0 0 0.2rem rgba(0, 148, 161, 0.25);
}

/* ClassMessage Brand Logo */
.classmessage-brand {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 20px;
}

.classmessage-icon {
    width: 56px;
    height: 42px;
    color: #0ea5e9;
}

.classmessage-text {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.classmessage-title {
    font-size: 2rem;
    font-weight: 700;
    color: #1f2937;
    letter-spacing: -0.02em;
}

.classmessage-title .class-part {
    color: #0ea5e9;
}

.classmessage-title .message-part {
    color: #10b981;
    font-style: italic;
}

/* ClassMessage Branding Overrides */
.classmessage-theme .btn-primary {
    background-color: #0ea5e9;
    border-color: #0ea5e9;
}

.classmessage-theme .btn-primary:hover {
    background-color: #0284c7;
    border-color: #0284c7;
}

.classmessage-theme .form-control:focus {
    border-color: #0ea5e9;
    box-shadow: 0 0 0 0.2rem rgba(14, 165, 233, 0.25);
}

.divider {
    display: flex;
    align-items: center;
    text-align: center;
    margin: 20px 0;
    color: #888;
}

.divider::before,
.divider::after {
    content: '';
    flex: 1;
    border-bottom: 1px solid #dee2e6;
}

.divider::before {
    margin-right: .5em;
}

.divider::after {
    margin-left: .5em;
}

.auth-footer {
    text-align: center;
    margin-top: 20px;
    font-size: 14px;
}

.auth-footer a {
    color: #666;
    text-decoration: none;
}

.auth-footer a:hover {
    text-decoration: underline;
}
